Update of /cvsroot/tmda/tmda-cgi/htdocs
In directory sc8-pr-cvs1:/tmp/cvs-serv31562

Added Files:
        tmda-cgi.ht tmda-cgi.html 
Log Message:
Moving documentation.  Will have to update it shortly.


--- NEW FILE ---
Title: tmda-cgi HOWTO

<h1>tmda-cgi (contributed by <a href="mailto:[EMAIL PROTECTED]">Gre7g 
Luterman</a>)</h1>
<p><a href="#What">What is it?</a><br>
  <a href="#Screen">Screenshots</a> <br>
  <a href="#Require">Requirements</a><br>
  <a href="#Blame">Credit/blame</a><br>
  <a href="#Install">Installation</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#SystemWide">System-wide mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#SingleUser">Single-user mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#nosu">no-su mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<a href="#nosuExample">Centralized 
  no-su setup</a><br>
  <a href="#Pass">Passwords</a><br>
  <a href="#Virtual">Virtual users</a><br>
  <a href="#Config">Configuration</a><br>
  <a href="#Surprise">Surprises &amp; gotcha's</a><br>
  <a href="#Template">Templates (URL confirmation)</a></p>
<hr>
<h2><a name="What"></a>What is it?</h2>

<p>tmda-cgi is an alpha-release program for managing your
TMDA account over the web. At the time of this writing, tmda-cgi
can:</p>
<ul>
  <li>Page through lists of pending e-mail (mail received by your MTA, but still 
    awaiting confirmation) 
  <li>View the text content (and see what sorts of attachments are included) in 
    any of your pending e-mails 
  <li>Release (move into your mail folder as if a confirmation had been received) 
    any of your pending e-mails. 
  <li>Delete any pending e-mail 
  <li>Whitelist or blacklist the author of any pending e-mails. 
</ul>
<p>At the moment, tmda-cgi's focus is clearly manipulating pending e-mails. At 
  some point, I would like tmda-cgi to become more of a general system tool. Features 
  I hope to add soon include:</p>
<ul>
  <li>Filter configuration</li>
  <li>List editing</li>
  <li>Automated clean-ups of pending e-mails</li>
  <li>E-mail address generation (keyword, dated, or sender)</li>
</ul>
<p>tmda-cgi provides quick and easy access to your pending e-mails. This is an 
  ideal tool for users who either do not have access to a shell account or are 
  intimidated by operating in a command-line environment.</p>
<p>Although TMDA users do not generally need to mess with their pending e-mails, 
  there are times when this is the most convenient way to go. For instance:</p>
<ul>
  <li>When you use a web site that says it will automatically mail you a password, 
    authentication link, or a receipt for a transaction you are making right now, 
    but you're not interested in any follow-up e-mail they will likely send you 
    in the future (and you don't feel like generating a dated address). 
    <p> Simply fill out the web form like you normally would and give your regular, 
      filtered e-mail address. The web site will send the e-mail to your mail 
      server, and your mail server will send a confirmation request back to the 
      web site (which will most likely never be seen by a human being). Then log 
      into tmda-cgi and manually release their letter. Any further mail they send 
      you will sit quietly in your pending directory like the one you released. 
  </li>
  <li>To search your incoming mail for automated mailings you want to receive. 
    <p> Using tmda-cgi regularly for a few weeks or months after you begin filtering 
      your e-mail is a good way to make sure your filters are configured correctly. 
  <li> 
    <p>To look for &quot;lost&quot; e-mail. 
    <p> It's really rare that e-mail will get lost, but it's bound to happen 
sometimes. 
      Perhaps Aunt Margaret can't figure out what the confirmation e-mail meant 
      (even though it is written in a very obvious way). Perhaps your boss was 
      in a hurry and deleted the confirmation request thinking 
<em><strong>it</strong></em> 
      was spam (or perhaps he has a really crappy spam filter that mistook the 
      confirmation for spam). Perhaps Grandpa Joe sent you some e-mail from someone 
      else's e-mail account and they deleted the confirmation request, not realizing 
      what it was. 
  <li> 
    <p>To remind you <em><strong>why</strong></em> you got TMDA in the first place. 
    <p> &quot;Wow, I would have gotten 100 e-mails about Viagara, cheap cigarettes, 
      weight loss drugs, penis enlargement, and Nigerian swindles today! Now I 
      remember why the rest of my family thinks that e-mail is a pain.&quot;
</ul>
<hr>
<h2><a name="Screen" id="Screen"></a>Screenshots</h2>
<p><b><i>Note:</i></b> You may find the default colors ugly. Those can be changed 
  by modifying the CSS file.</p>
<p><a href="http://tmda.sourceforge.net/screenshots/login.png"; 
target="_blank">Login</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/pending.png"; target="_blank">Index 
  of pending e-mails (whitelist &amp; blacklist options enabled)</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/view1.png"; target="_blank">View 
  the contents of a pending e-mail with attachements</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/confirm.png"; 
target="_blank">Optional 
  Javascript confirmation when deleting or blacklisting</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/view2.png"; target="_blank">Show 
  all headers mode when viewing an e-mail</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/confirmed.png"; target="_blank">URL 
confirmation 
  feedback</a></p>
<hr>
<h2><a name="Require"></a>Requirements</h2>
<p>TBD. Until we do more testing it isn't clear what systems have problems with 
  tmda-cgi.</p>
<hr>
<h2><a name="Blame" id="Blame"></a>Credit/blame</h2>
<p>As already mentioned, this is contributed software at an alpha-level release. 
  That means:</p>
<ul>
  <li>Use at your own risk. 
    <p>That's true of all software in general, but we're telling you up front 
      that not a lot of people have tested or analyzed the code yet. If it goes 
      awry or opens a security hole on your machine, I won't drop dead from the 
      shock.</p>
  </li>
  <li>tmda-cgi was written by <a href="mailto:[EMAIL PROTECTED]">Gre7g Luterman</a>,
      with support from Jason R. Mastaler, David Guerizec, Tim Legant, and others on 
      the TMDA lists.
  </li>
</ul>
<hr>
<h2><a name="Install"></a>Installation</h2>
<p>tmda-cgi is provided in your distribution's <tt>contrib/cgi</tt> directory.</p>
<p>Once you've obtained a copy of tmda-cgi, you need to decide how you want to 
  use tmda-cgi. tmda-cgi has been designed to run three different ways: system-wide, 
  single-user, and in no-su modes.</p>
<ul>
  <li>In system-wide mode, multiple users can use tmda-cgi to access their TMDA 
    system. The program launches as root and then performs a <tt>seteuid</tt> 
    to run as the requested user once password authentication has been accomplished. 
    This is the best solution for system administrators who wish to set up their 
    TMDA system for use by multiple users.<br>
  </li>
  <li>In single-user mode, only one user can access tmda-cgi. That user will still 
    need to authenticate their access with a password, but the program runs as 
    the user who compiled it and therefore cannot access anyone else's personal 
    data. If multiple users wish to install tmda-cgi in single-user mode (strange, 
    but not absurd) then each user can compile a different 14k shell that launches 
    the Python code. This method is less convenient than the system-wide installation, 
    but it is the best solution for users without root access to their server, 
    or for users who don't trust any program running as root that does not absolutely 
    have to run as root.<br>
  </li>
  <li>no-su mode, which is in testing, runs the program with no special privileges 
    of any sort. The downside of such an installation is that to allow the program 
    access to your personal files (such as pending e-mails) you will have to make 
    some of your files and directories group or world readable and writable. no-su 
    mode is a good solution for an unusual breed of user: someone who doesn't 
    trust the software, but trusts the other users on the server (since they could 
    get read/write access to his/er pending e-mail)</li>
</ul>
<p><b><i>Notes:</i></b></p>
<ul>
  <li>tmda-cgi assumes it will run from within the source tree. No testing has 
    been done to date to see if it will work in other locations.<br>
  </li>
  <li>You will have to recompile tmda-cgi if you move your configuration files, 
    supplimental display files (icons and style sheet), or source tree.<br>
  </li>
  <li>You will have to recompile tmda-cgi if you change which mode (system-wide, 
    single-user, or no-su) you run in.</li>
</ul>
<h3><a name="SystemWide"></a>Installing system-wide</h3>
<p>As root, change to the cgi directory.</p>
<blockquote> 
  <pre># cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre># ./compile -t /path/to/cgi-bin/directory</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre># ./compile -t /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p>Finally, tmda-cgi expects to find a variety of visual elements in web directory 
  <tt>../display/</tt>, relative to the CGI itself. The location of this directory 
  may be changed with <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided 
  in <tt>contrib/cgi/display</tt>. Feel free to use these files as-is or 
modify/replace 
  them to personalize the program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre># ln -s display /path/to/webpage/directory</pre>
</blockquote>
<h3><a name="SingleUser"></a>Installing single-user</h3>
<p>As the (only) user who will be able to access tmda-cgi, change to the cgi 
directory.</p>
<blockquote> 
  <pre>$ cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre>$ ./compile -t /path/to/cgi-bin/directory</pre>
</blockquote>
<p>or</p>
<blockquote> 
  <pre>$ ./compile -t /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p>Finally, tmda-cgi expects to find a variety of visual elements in web directory 
  <tt>../display/</tt>, relative to the CGI itself. The location of this directory 
  may be changed with <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided 
  in <tt>contrib/cgi/display</tt>. Feel free to use these files as-is or 
modify/replace 
  them to personalize the program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre>$ ln -s display /path/to/webpage/directory</pre>
</blockquote>
<h3><a name="nosu"></a>Installing no-su</h3>
<p>To compile tmda-cgi for no-su mode, first change to the cgi directory.</p>
<blockquote> 
  <pre>$ cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre>$ ./compile -nt /path/to/cgi-bin/directory</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre>$ ./compile -nt /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p> tmda-cgi expects to find a variety of visual elements in web directory 
<tt>../display/</tt>, 
  relative to the CGI itself. The location of this directory may be changed with 
  <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided in 
<tt>contrib/cgi/display</tt>. 
  Feel free to use these files as-is or modify/replace them to personalize the 
  program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre>$ ln -s display /path/to/webpage/directory</pre>
</blockquote>
<p>At this point you will have to change permissions on any existing pending mail 
  and add something akin to:</p>
<blockquote> 
  <pre>os.umask(027)</pre>
</blockquote>
<p>to your configuration file. That will make sure that future pending e-mails 
  are written such that they can be read by group members (i.e. the CGI).</p>
<h4><a name="nosuExample"></a>Centralized no-su setup</h4>
<p>If you multiple users plan on using tmda-cgi in no-su mode, then you might 
  consider moving all of your TMDA files into one central location. This will 
  make it easier to keep group permissions on your directories and files. Here's 
  some sample directories and file contents I set up for my user <tt>cgitest</tt>:</p>
<blockquote> <tt>/etc:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r--r-- &nbsp; &nbsp;1 root &nbsp; 
&nbsp; root &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 22 Nov 24 23:54 tmda-cgi<br>
-rw-r--r-- &nbsp; &nbsp;1 root &nbsp; &nbsp; root &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp;557 Nov 27 15:05 tmdarc<br>
-rw------- &nbsp; &nbsp;1 tofmipd &nbsp;tofmipd &nbsp; &nbsp; &nbsp; &nbsp;49 Nov 10 
11:02 tofmipd</tt></td>
    </tr>
  </table><br>
  <tt>/var:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>drwxr-s--x &nbsp; &nbsp;3 root &nbsp; 
&nbsp; nobody &nbsp; &nbsp; &nbsp; &nbsp; 72 Nov 27 11:24 tmda</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>drwx--s--- &nbsp; &nbsp;6 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;200 Nov 27 11:39 cgitest</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r----- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 11:39 config<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 41 Nov 27 
11:39 crypt_key<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 96 Nov 27 
12:55 filters<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;144 Nov 27 
12:59 lists<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;120 Nov 27 
12:57 logs<br>
drwxrws--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 48 Nov 27 
11:37 pending<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;768 Nov 29 
09:54 responses<br>
drwxr-sr-x &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;200 Dec 
&nbsp;6 20:33 templates</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-rw---- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;153 Nov 27 12:54 incoming<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;150 Nov 27 
12:55 outgoing</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/lists:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-rw---- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 12:59 blacklist<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:59 confirmed<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:59 whitelist</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/logs:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r----- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 12:57 debug<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:57 in<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:57 out</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/templates:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r--r-- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;407 Dec &nbsp;6 20:30 bounce.txt<br>
-rw-r--r-- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;215 Dec 
&nbsp;6 20:30 confirm_accept.txt<br>
-rw-r--r-- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;702 Dec 
&nbsp;6 20:33 confirm_request.txt</tt></td>
    </tr>
  </table><br>
  <tt>/etc/tmda-cgi:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>cgitest:XPkY0q/9Uge9I</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters/incoming:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>from-file 
/var/tmda/cgitest/lists/blacklist reject<br>
from-file /var/tmda/cgitest/lists/whitelist accept<br>
from-file /var/tmda/cgitest/lists/confirmed accept</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters/outgoing:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>to-file /var/tmda/cgitest/lists/whitelist 
tag envelope dated=10d from bare<br>
to-file /var/tmda/cgitest/lists/confirmed tag envelope dated=10d from bare</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/templates/confirm_request.txt:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>From.US-ASCII: "%(FULLNAME)s" 
<%(recipient_address)s><br>
Subject.US-ASCII: Please confirm your message<br>
Reply-To.US-ASCII: %(confirm_accept_address)s<br>
BodyCharset: US-ASCII<br>
&nbsp;<br>
This message was created automatically by mail delivery software<br>
(TMDA).<br>
&nbsp;<br>
Your message attached below is being held because the address<br>
<%(confirm_append_address)s> has not been verified.<br>
&nbsp;<br>
To release your message for delivery, please send an empty message<br>
to the following address, surf the following link, or use your<br>
mailer's "Reply" feature.<br>
&nbsp;<br>
 &nbsp; %(confirm_accept_address)s<br>
&nbsp;<br>
 &nbsp; %(confirm_accept_url)s<br>
&nbsp;<br>
This confirmation verifies that your message is legitimate and not<br>
junk-mail. You should only have to confirm your address once.</tt></td>
    </tr>
  </table><br>
  <tt>/etc/tmdarc:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>import Util<br>
&nbsp;<br>
# Allow group access to critical files<br>
ALLOW_MODE_640 = 1<br>
os.umask(0027)<br>
&nbsp;<br>
# Locate important files and directories<br>
DATADIR = "/var/tmda/%s/" % os.environ["USER"]<br>
        CONFIRM_APPEND &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + 
"lists/confirmed"<br>
FILTER_INCOMING &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "filters/incoming"<br>
FILTER_OUTGOING &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "filters/outgoing"<br>
LOGFILE_DEBUG &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "logs/debug"<br>
LOGFILE_INCOMING &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "logs/in"<br>
LOGFILE_OUTGOING &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "logs/out"<br>
PENDING_BLACKLIST_APPEND = DATADIR + "lists/blacklist"<br>
PENDING_WHITELIST_APPEND = DATADIR + "lists/whitelist"<br>
TEMPLATE_DIR &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "templates/"<br>
&nbsp;<br>
# CGI location<br>
CGI_URL = "http://wolfhome.com/~cgitest/index2.cgi";<br>
<br>
# Define X-Primary-Address key for TMDA-to-TMDA communications<br>
ADDED_HEADERS_CLIENT = { "X-Primary-Address": "[EMAIL PROTECTED]" % \<br>
 &nbsp;(os.environ["USER"], Util.gethostname()) }</tt></td>
    </tr>
  </table><br>
  <tt>~cgitest/.qmail:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>|preline /usr/src/tmda/bin/tmda-filter -c 
/var/tmda/cgitest/config<br>
./Maildir/</tt></td>
    </tr>
  </table>
</blockquote>
<p>tmda-cgi was compiled with the following:</p>
<blockquote> 
  <pre>./compile -nc /var/tmda/~/config -t /www/tmda.cgi</pre>
</blockquote>
<p>Use the <tt>./compile -h</tt> for more details on how to use compile.</p>
<hr>
<h2><a name="Pass"></a>Passwords</h2>
<p>tmda-cgi currently authenticate logins against user name &amp; password pairs 
  stored in a password file (or files). tmda-cgi will look in two different places 
  for password file(s), but it (they) must be readable by the CGI.</p>
<p>If you are running in system-wide mode, the password file can be owned by root. 
  If you are running in single-user mode, the password file can be owned by the 
  user who will be running the CGI. If you are running in no-su mode, the file 
  must either be owned by &quot;nobody&quot; (or whatever user your web server 
  is configured to run as) or made globally readable See the table below for a 
  better breakdown of your options.</p>
<p>tmda-cgi first checks for a readable file called <tt>tmda-cgi</tt> in the same 
  directory as the user's configuration file (if that location has been specified, 
  otherwise it will look in <tt>~user/.tmda/tmda-cgi</tt>). It then tries 
<tt>/etc/tmda-cgi</tt> 
  if it can't find a match or cannot read the file. This allows the system 
administrator 
  to keep a list of access passwords while allowing the user to override what 
  the sysadmin has set.</p>
<table border="0" cellpadding="0" cellspacing="0">
  <tr> 
    <td width="35">&nbsp;</td>
    <td width="10">&nbsp;</td>
    <td>&nbsp;</td>
    <td width="10">&nbsp;</td>
    <td colspan="2" align="center" nowrap 
bgcolor="#FFFFCC"><tt>~user/.tmda/tmda-cgi</tt></td>
    <td width="10" align="center" nowrap>&nbsp;</td>
    <td colspan="2" align="center" nowrap bgcolor="#FFFFCC"><tt>/etc/tmda-cgi</tt></td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td width="80" align="center" bgcolor="#FFFFCC">owner</td>
    <td width="90" align="center" bgcolor="#FFFFCC">permissions</td>
    <td align="center">&nbsp;</td>
    <td width="80" align="center" bgcolor="#FFFFCC">owner</td>
    <td width="90" align="center" bgcolor="#FFFFCC">permissions</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td bgcolor="#CCFFFF">system-wide</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">user</td>
    <td align="center" bgcolor="#CCFFCC">600</td>
    <td align="center" bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">root</td>
    <td align="center" bgcolor="#CCFFCC">600</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>single-user</td>
    <td>&nbsp;</td>
    <td align="center" bgcolor="#FFFFCC">user</td>
    <td align="center" bgcolor="#FFFFCC">600</td>
    <td align="center">&nbsp;</td>
    <td colspan="2" align="center" bgcolor="#FFFFCC">n/a</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td bgcolor="#CCFFFF">no-su</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">user</td>
    <td align="center" bgcolor="#CCFFCC">644</td>
    <td align="center" bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">root<br>
      nobody </td>
    <td align="center" bgcolor="#CCFFCC">644<br>
      600 </td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td colspan="8" align="center">File owner &amp; permission options</td>
  </tr>
</table>
<p>The password file for tmda-cgi is formatted in much the same way as the password 
  file for tofmipd. In fact, if you are using a password file with tofmipd and 
  you wish to run tmda-cgi in system-wide mode, feel free to make a symbolic link 
  between the two:</p>
<blockquote> 
  <pre> # ln -s /etc/tofmipd /etc/tmda-cgi</pre>
</blockquote>
<p>Password files for tmda-cgi look like:</p>
<blockquote> 
  <pre>&lt;user1&gt;:&lt;password1&gt;
&lt;user2&gt;:&lt;password2&gt;</pre>
</blockquote>
<p>where each item in <tt>&lt;&gt;</tt> is replaced with text.</p>
<p>The difference between this password file and the one for tofmipd is that the 
  file does not need to have <br>
  permissions of 400 or 600. If you, for example, are running in no-su mode, you 
  will have to make your password file group or world readable.</p>
<p>To keep the passwords secure, tmda-cgi will assume all passwords are DES encrypted 
  if the file permissions are anything other than 400 or 600. Plaintext passwords 
  will <i><b>not</b></i> work in such cases.</p>
<p>Additionally, any entry with a blank password field, such as:</p>
<blockquote> 
  <pre>cantlogin:</pre>
</blockquote>
<p>will be prohibited from login, regardless of the file permissions.</p>
<p><tt>contrib/cgi/genpass.py</tt> is provided for encrypted password generation. 
  Output from <tt>genpass.py</tt> can be safely piped with <tt>&gt;</tt> or 
<tt>&gt;&gt;</tt> 
  into a password file. For example:</p>
<blockquote> 
  <pre># contrib/cgi/genpass.py joe &gt;&gt; /etc/tmda-cgi</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre>$ contrib/cgi/genpass.py joe &gt; /home/joe/.tmda/tmda-cgi</pre>
</blockquote>
<p>If you encounter difficulties logging in, the problem may be a result of incorrect 
  permissions on your password file(s). To debug this, append a <tt>?debug=1</tt> 
  onto the end of your CGI URL. This will display some diagnostic information 
  if the login fails instead of simply saying &quot;Wrong password. Try 
again.&quot;</p>
<hr>
<h2><a name="Virtual" id="Virtual"></a>Virtual users</h2>
<p>Although planned for future releases, there is no support for virtual users 
  at this time. Each user who plans to use tmda-cgi must have a login record in 
  <tt>/etc/passwd</tt>.</p>
<hr>
<h2><a name="Config"></a>Configuration</h2>
<p>tmda-cgi is configured by a set of parameters in your configuration file(s). 
  All tmda-cgi configuration variables begin with a &quot;<tt>CGI_</tt>&quot; 
  and are described on the <a href="config-vars.html">Configuration Variables</a> 
  page.</p>
<p><em><strong>Note:</strong></em> If you change nothing else, you will have to 
  at least set the value for <a 
href="config-vars.html#CGI_ACTIVE"><tt>CGI_ACTIVE</tt></a>.</p>
<hr>
<h2><a name="Surprise" id="Surprise"></a>Surprises &amp; gotcha's</h2>
<p>This section of the documentation is reserved for functionality and quirks 
  that, although not erroneous, may not be what you expect. Check this list for 
  help if you experience problems with tmda-cgi.</p>
<ol>
  <li>tmda-cgi's whitelist feature does not update the list pointed to by 
configuration 
    variable <tt><a 
href="/config-vars.html#CONFIRM_APPEND">CONFIRM_APPEND</a></tt><tt>.</tt> 
    <p>tmda-cgi uses configuration variable <a 
href="/config-vars.html#PENDING_WHITELIST_APPEND"><tt>PENDING_WHITELIST_APPEND</tt></a>
 
      instead of <tt><a 
href="/config-vars.html#CONFIRM_APPEND">CONFIRM_APPEND</a>.</tt> 
      To use the whitelist feature, you must set <a 
href="/config-vars.html#PENDING_WHITELIST_APPEND"><tt>PENDING_WHITELIST_APPEND</tt></a>
 
      to a list that is handled by your incoming filter.<p></li>
  <li>TMDA requires Python version 2.1 but some flavors of Linux (such as <a 
href="http://redhat.com";>RedHat</a>) 
    come with two different versions of Python installed, one older and one newer. 
    <p>If tmda-cgi tries to run using the wrong version of Python, then you must 
      specify the correct version at compile time. Instead of typing:
    <blockquote>
          <pre>$ ./compile &lt;options&gt;</pre>
        </blockquote>
    <p>Type:</p>
        <blockquote>
          <pre>$ /usr/bin/python2 compile &lt;options&gt;</pre>
        </blockquote>
    <p>(Assuming that your Python 2.1+ can be found at <tt>/usr/bin/python2</tt>.) 
      The compiler will save the correct version of the Python interpreter and 
      use it when tmda-cgi is run.</p>
        </li>
</ol>
<hr>
<h2><a name="Template" id="Template"></a>Templates</h2>
<p>By supplying your own templates (see the <a href="howto-template.html">Template 
  HOWTO</a> for more on customizing your templates) you can use tmda-cgi's URL 
  confirmation feature. This allows you to specify a URL in your confirmation 
  e-mail as an alternative to confirming by e-mail.</p>
<p>To supply a confirmation URL, simply use the <tt>%(confirm_accept_url)s</tt> 
  variable in <tt>confirm_request.txt</tt> as shown in <a 
href="#nosuExample">Centralized 
  no-su setup</a>.</p>
<p><em><strong>Notes:</strong></em></p>
<ul>
  <li>Be sure you set <a href="config-vars.html#CGI_ACTIVE"><tt>CGI_ACTIVE</tt></a>, 
    <a href="config-vars.html#CGI_URL"><tt>CGI_URL</tt></a>, and <a 
href="config-vars.html#TEMPLATE_DIR"><tt>TEMPLATE_DIR</tt></a> 
    before modifying your template! No confirmation e-mails will be sent if you 
    specify a <tt>%(confirm_accept_url)</tt> until these variables are properly 
    configured.<br>
  </li>
  <li>Always test your configuration after making a change to your templates.<br>
  </li>
  <li>Your crypt_key file must be readible by tmda-cgi to use this feature. 
    <p>This is not and issue if you are running in system-wide orf single-user 
      modes, but in no-su mode, you will have to:</p>
  </li>
  <ul>
    <li>Put crypt_key in the CGI's group.</li>
    <li>Assign crypt_key 640 permissions.</li>
    <li>Turn on <a href="config-vars.html#ALLOW_MODE_640">ALLOW_MODE_640</a>.<br>
    </li>
  </ul>
</ul>

--- NEW FILE ---
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<!-- THIS PAGE IS AUTOMATICALLY GENERATED.  DO NOT EDIT. -->
<!-- Mon Mar 17 16:18:15 2003 -->
<!-- USING HT2HTML 2.0 -->
<!-- SEE http://ht2html.sf.net -->
<!-- User-specified headers:
Title: tmda-cgi HOWTO

-->

<head>
<title>tmda-cgi HOWTO</title>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="generator" content="HT2HTML/2.0">
<style type="text/css">
body { margin: 0px; }
</style>
</head>
<body bgcolor="#ffffff" text="#000000"
      marginwidth="0" marginheight="0"
      link="#0000bb"  vlink="#551a8b"
      alink="#ff0000">
<!-- start of page table -->
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<!-- start of banner row -->
<tr>
<!-- start of corner cells -->
<td width="150" valign="middle" bgcolor="#afeeee" class="corner">
<center><font size="+2"
        >&gt;&gt;&gt;&nbsp;TMDA&nbsp</font></center> </td>
<td width="15" bgcolor="#cccccc">&nbsp;&nbsp;</td><!--spacer-->
<!-- end of corner cells -->
<!-- start of banner -->
<td width="90%" bgcolor="#cccccc" class="banner">
<!-- start of site links table -->
<table width="100%" border="0"
CELLSPACING=0 CELLPADDING=0
       bgcolor="#ffffff">
<tr>
    <td bgcolor="#cccccc">
<a href="./index.html">TMDA Homepage</a><br>[    <a 
href="http://www.au.tmda.net/";>AU</a> |    <a href="http://www.us.tmda.net/";>US</a>    
 mirror ]
    </td>
    <td bgcolor="#cccccc">
<a href="http://sourceforge.net/projects/tmda";>TMDA @ SourceForge</a>
    </td>
    <td bgcolor="#cccccc">
&nbsp;&nbsp;</td>
    <td bgcolor="#cccccc">
&nbsp;&nbsp;</td>
</tr>
</table><!-- end of site links table -->

</td><!-- end of banner -->
</tr><!-- end of banner row -->
<tr><!-- start of sidebar/body row -->
<!-- start of sidebar cells -->
<td width="150" valign="top" bgcolor="#cccccc" class="sidebar">
<!-- start of sidebar table -->
<table width="100%" border="0" cellspacing="0" cellpadding="3"
       bgcolor="#ffffff">
<tr><td bgcolor="#191970"><b><font color="#ffffff">
Overview
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="index.html">Introduction</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="history.html">History</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="features.html">Features</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="results.html">Results &amp; Testimonials</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="inuse.html">TMDA In Use</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="press.html">Press Coverage</a><!-- -*- html -*- -->
</td></tr>
<tr><td bgcolor="#cccccc">&nbsp;
<tr><td bgcolor="#191970"><b><font color="#ffffff">
Install
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="requirements.html">Requirements</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="download.html">Download</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="install.html">Installation</a>
</td></tr>
<tr><td bgcolor="#cccccc">&nbsp;
<tr><td bgcolor="#191970"><b><font color="#ffffff">
Configuration
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="config.html">Overview</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="config-pre.html">Pre-Configuration</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="config-server.html">Server Configuration</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="config-client.html">Client Configuration</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="config-vars.html">Configuration Variables</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="config-filter.html">Filter Specification</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="filter-sources.html">Filter Sources</a>
</td></tr>
<tr><td bgcolor="#cccccc">&nbsp;
<tr><td bgcolor="#191970"><b><font color="#ffffff">
HOWTOs
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="howtos.html">Overview</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="howto-template.html">Templates</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="tmda-ofmipd.html">tmda-ofmipd</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="tmda-vdomains.html">Virtual Domains</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<b>tmda-cgi</b>
</td></tr>
<tr><td bgcolor="#cccccc">&nbsp;
<tr><td bgcolor="#191970"><b><font color="#ffffff">
Support
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="trouble.html">Troubleshooting</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="http://tmda.net/faq.cgi"; TARGET="Resource Window">FAQ</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="bugs.html">Bugs &amp; Patches</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="http://tmda.net/lists/listinfo/"; TARGET="Resource Window">Mailing Lists</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="http://mla.libertine.org/"; TARGET="Resource Window">List Archive</a> 
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="support-commercial.html">Commercial Support</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="resources.html">External Resources</a>
</td></tr>
<tr><td bgcolor="#cccccc">
<a href="mirrors.html">Mirrors</a>
</td></tr>
<tr><td bgcolor="#cccccc">&nbsp;
<tr><td bgcolor="#191970"><b><font color="#ffffff">
Author
</font></b></td></tr>
<tr><td bgcolor="#cccccc">
<a href="mailto:[EMAIL PROTECTED]">Jason R. Mastaler</a>
</td></tr>
<tr><td bgcolor="#cccccc">
&nbsp;
</td></tr>
<tr><td bgcolor="#cccccc">
&copy; 2001-2003
</td></tr>
</table><!-- end of sidebar table -->

</td>
<td width="15">&nbsp;&nbsp;</td><!--spacer-->
<!-- end of sidebar cell -->
<!-- start of body cell -->
<td valign="top" width="90%" class="body"><br>
<h1>tmda-cgi (contributed by <a href="mailto:[EMAIL PROTECTED]">Gre7g 
Luterman</a>)</h1>
<p><a href="#What">What is it?</a><br>
  <a href="#Screen">Screenshots</a> <br>
  <a href="#Require">Requirements</a><br>
  <a href="#Blame">Credit/blame</a><br>
  <a href="#Install">Installation</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#SystemWide">System-wide mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#SingleUser">Single-user mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;<a href="#nosu">no-su mode</a><br>
  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<a href="#nosuExample">Centralized 
  no-su setup</a><br>
  <a href="#Pass">Passwords</a><br>
  <a href="#Virtual">Virtual users</a><br>
  <a href="#Config">Configuration</a><br>
  <a href="#Surprise">Surprises &amp; gotcha's</a><br>
  <a href="#Template">Templates (URL confirmation)</a></p>
<hr>
<h2><a name="What"></a>What is it?</h2>

<p>tmda-cgi is an alpha-release program for managing your
TMDA account over the web. At the time of this writing, tmda-cgi
can:</p>
<ul>
  <li>Page through lists of pending e-mail (mail received by your MTA, but still 
    awaiting confirmation) 
  <li>View the text content (and see what sorts of attachments are included) in 
    any of your pending e-mails 
  <li>Release (move into your mail folder as if a confirmation had been received) 
    any of your pending e-mails. 
  <li>Delete any pending e-mail 
  <li>Whitelist or blacklist the author of any pending e-mails. 
</ul>
<p>At the moment, tmda-cgi's focus is clearly manipulating pending e-mails. At 
  some point, I would like tmda-cgi to become more of a general system tool. Features 
  I hope to add soon include:</p>
<ul>
  <li>Filter configuration</li>
  <li>List editing</li>
  <li>Automated clean-ups of pending e-mails</li>
  <li>E-mail address generation (keyword, dated, or sender)</li>
</ul>
<p>tmda-cgi provides quick and easy access to your pending e-mails. This is an 
  ideal tool for users who either do not have access to a shell account or are 
  intimidated by operating in a command-line environment.</p>
<p>Although TMDA users do not generally need to mess with their pending e-mails, 
  there are times when this is the most convenient way to go. For instance:</p>
<ul>
  <li>When you use a web site that says it will automatically mail you a password, 
    authentication link, or a receipt for a transaction you are making right now, 
    but you're not interested in any follow-up e-mail they will likely send you 
    in the future (and you don't feel like generating a dated address). 
    <p> Simply fill out the web form like you normally would and give your regular, 
      filtered e-mail address. The web site will send the e-mail to your mail 
      server, and your mail server will send a confirmation request back to the 
      web site (which will most likely never be seen by a human being). Then log 
      into tmda-cgi and manually release their letter. Any further mail they send 
      you will sit quietly in your pending directory like the one you released. 
  </li>
  <li>To search your incoming mail for automated mailings you want to receive. 
    <p> Using tmda-cgi regularly for a few weeks or months after you begin filtering 
      your e-mail is a good way to make sure your filters are configured correctly. 
  <li> 
    <p>To look for &quot;lost&quot; e-mail. 
    <p> It's really rare that e-mail will get lost, but it's bound to happen 
sometimes. 
      Perhaps Aunt Margaret can't figure out what the confirmation e-mail meant 
      (even though it is written in a very obvious way). Perhaps your boss was 
      in a hurry and deleted the confirmation request thinking 
<em><strong>it</strong></em> 
      was spam (or perhaps he has a really crappy spam filter that mistook the 
      confirmation for spam). Perhaps Grandpa Joe sent you some e-mail from someone 
      else's e-mail account and they deleted the confirmation request, not realizing 
      what it was. 
  <li> 
    <p>To remind you <em><strong>why</strong></em> you got TMDA in the first place. 
    <p> &quot;Wow, I would have gotten 100 e-mails about Viagara, cheap cigarettes, 
      weight loss drugs, penis enlargement, and Nigerian swindles today! Now I 
      remember why the rest of my family thinks that e-mail is a pain.&quot;
</ul>
<hr>
<h2><a name="Screen" id="Screen"></a>Screenshots</h2>
<p><b><i>Note:</i></b> You may find the default colors ugly. Those can be changed 
  by modifying the CSS file.</p>
<p><a href="http://tmda.sourceforge.net/screenshots/login.png"; 
target="_blank">Login</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/pending.png"; target="_blank">Index 
  of pending e-mails (whitelist &amp; blacklist options enabled)</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/view1.png"; target="_blank">View 
  the contents of a pending e-mail with attachements</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/confirm.png"; 
target="_blank">Optional 
  Javascript confirmation when deleting or blacklisting</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/view2.png"; target="_blank">Show 
  all headers mode when viewing an e-mail</a></p>
<p><a href="http://tmda.sourceforge.net/screenshots/confirmed.png"; target="_blank">URL 
confirmation 
  feedback</a></p>
<hr>
<h2><a name="Require"></a>Requirements</h2>
<p>TBD. Until we do more testing it isn't clear what systems have problems with 
  tmda-cgi.</p>
<hr>
<h2><a name="Blame" id="Blame"></a>Credit/blame</h2>
<p>As already mentioned, this is contributed software at an alpha-level release. 
  That means:</p>
<ul>
  <li>Use at your own risk. 
    <p>That's true of all software in general, but we're telling you up front 
      that not a lot of people have tested or analyzed the code yet. If it goes 
      awry or opens a security hole on your machine, I won't drop dead from the 
      shock.</p>
  </li>
  <li>tmda-cgi was written by <a href="mailto:[EMAIL PROTECTED]">Gre7g Luterman</a>,
      with support from Jason R. Mastaler, David Guerizec, Tim Legant, and others on 
      the TMDA lists.
  </li>
</ul>
<hr>
<h2><a name="Install"></a>Installation</h2>
<p>tmda-cgi is provided in your distribution's <tt>contrib/cgi</tt> directory.</p>
<p>Once you've obtained a copy of tmda-cgi, you need to decide how you want to 
  use tmda-cgi. tmda-cgi has been designed to run three different ways: system-wide, 
  single-user, and in no-su modes.</p>
<ul>
  <li>In system-wide mode, multiple users can use tmda-cgi to access their TMDA 
    system. The program launches as root and then performs a <tt>seteuid</tt> 
    to run as the requested user once password authentication has been accomplished. 
    This is the best solution for system administrators who wish to set up their 
    TMDA system for use by multiple users.<br>
  </li>
  <li>In single-user mode, only one user can access tmda-cgi. That user will still 
    need to authenticate their access with a password, but the program runs as 
    the user who compiled it and therefore cannot access anyone else's personal 
    data. If multiple users wish to install tmda-cgi in single-user mode (strange, 
    but not absurd) then each user can compile a different 14k shell that launches 
    the Python code. This method is less convenient than the system-wide installation, 
    but it is the best solution for users without root access to their server, 
    or for users who don't trust any program running as root that does not absolutely 
    have to run as root.<br>
  </li>
  <li>no-su mode, which is in testing, runs the program with no special privileges 
    of any sort. The downside of such an installation is that to allow the program 
    access to your personal files (such as pending e-mails) you will have to make 
    some of your files and directories group or world readable and writable. no-su 
    mode is a good solution for an unusual breed of user: someone who doesn't 
    trust the software, but trusts the other users on the server (since they could 
    get read/write access to his/er pending e-mail)</li>
</ul>
<p><b><i>Notes:</i></b></p>
<ul>
  <li>tmda-cgi assumes it will run from within the source tree. No testing has 
    been done to date to see if it will work in other locations.<br>
  </li>
  <li>You will have to recompile tmda-cgi if you move your configuration files, 
    supplimental display files (icons and style sheet), or source tree.<br>
  </li>
  <li>You will have to recompile tmda-cgi if you change which mode (system-wide, 
    single-user, or no-su) you run in.</li>
</ul>
<h3><a name="SystemWide"></a>Installing system-wide</h3>
<p>As root, change to the cgi directory.</p>
<blockquote> 
  <pre># cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre># ./compile -t /path/to/cgi-bin/directory</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre># ./compile -t /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p>Finally, tmda-cgi expects to find a variety of visual elements in web directory 
  <tt>../display/</tt>, relative to the CGI itself. The location of this directory 
  may be changed with <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided 
  in <tt>contrib/cgi/display</tt>. Feel free to use these files as-is or 
modify/replace 
  them to personalize the program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre># ln -s display /path/to/webpage/directory</pre>
</blockquote>
<h3><a name="SingleUser"></a>Installing single-user</h3>
<p>As the (only) user who will be able to access tmda-cgi, change to the cgi 
directory.</p>
<blockquote> 
  <pre>$ cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre>$ ./compile -t /path/to/cgi-bin/directory</pre>
</blockquote>
<p>or</p>
<blockquote> 
  <pre>$ ./compile -t /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p>Finally, tmda-cgi expects to find a variety of visual elements in web directory 
  <tt>../display/</tt>, relative to the CGI itself. The location of this directory 
  may be changed with <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided 
  in <tt>contrib/cgi/display</tt>. Feel free to use these files as-is or 
modify/replace 
  them to personalize the program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre>$ ln -s display /path/to/webpage/directory</pre>
</blockquote>
<h3><a name="nosu"></a>Installing no-su</h3>
<p>To compile tmda-cgi for no-su mode, first change to the cgi directory.</p>
<blockquote> 
  <pre>$ cd contrib/cgi</pre>
</blockquote>
<p>Compile tmda-cgi to a web directory that is configured to execute CGI. The 
  filename you use is completely up to you. For example:</p>
<blockquote> 
  <pre>$ ./compile -nt /path/to/cgi-bin/directory</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre>$ ./compile -nt /path/to/webpage/directory/index.cgi</pre>
</blockquote>
<p> tmda-cgi expects to find a variety of visual elements in web directory 
<tt>../display/</tt>, 
  relative to the CGI itself. The location of this directory may be changed with 
  <tt>compile</tt>'s <tt>-d</tt> flag. Sample files are provided in 
<tt>contrib/cgi/display</tt>. 
  Feel free to use these files as-is or modify/replace them to personalize the 
  program.</p>
<p>The simplest way to provide this directory is with a symbolic link (assuming 
  you have you web server configured to follow symbolic links). For example:</p>
<blockquote> 
  <pre>$ ln -s display /path/to/webpage/directory</pre>
</blockquote>
<p>At this point you will have to change permissions on any existing pending mail 
  and add something akin to:</p>
<blockquote> 
  <pre>os.umask(027)</pre>
</blockquote>
<p>to your configuration file. That will make sure that future pending e-mails 
  are written such that they can be read by group members (i.e. the CGI).</p>
<h4><a name="nosuExample"></a>Centralized no-su setup</h4>
<p>If you multiple users plan on using tmda-cgi in no-su mode, then you might 
  consider moving all of your TMDA files into one central location. This will 
  make it easier to keep group permissions on your directories and files. Here's 
  some sample directories and file contents I set up for my user <tt>cgitest</tt>:</p>
<blockquote> <tt>/etc:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r--r-- &nbsp; &nbsp;1 root &nbsp; 
&nbsp; root &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 22 Nov 24 23:54 tmda-cgi<br>
-rw-r--r-- &nbsp; &nbsp;1 root &nbsp; &nbsp; root &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp;557 Nov 27 15:05 tmdarc<br>
-rw------- &nbsp; &nbsp;1 tofmipd &nbsp;tofmipd &nbsp; &nbsp; &nbsp; &nbsp;49 Nov 10 
11:02 tofmipd</tt></td>
    </tr>
  </table><br>
  <tt>/var:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>drwxr-s--x &nbsp; &nbsp;3 root &nbsp; 
&nbsp; nobody &nbsp; &nbsp; &nbsp; &nbsp; 72 Nov 27 11:24 tmda</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>drwx--s--- &nbsp; &nbsp;6 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;200 Nov 27 11:39 cgitest</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r----- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 11:39 config<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 41 Nov 27 
11:39 crypt_key<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 96 Nov 27 
12:55 filters<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;144 Nov 27 
12:59 lists<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;120 Nov 27 
12:57 logs<br>
drwxrws--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; 48 Nov 27 
11:37 pending<br>
drwx--s--- &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;768 Nov 29 
09:54 responses<br>
drwxr-sr-x &nbsp; &nbsp;2 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;200 Dec 
&nbsp;6 20:33 templates</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-rw---- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;153 Nov 27 12:54 incoming<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;150 Nov 27 
12:55 outgoing</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/lists:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-rw---- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 12:59 blacklist<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:59 confirmed<br>
-rw-rw---- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:59 whitelist</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/logs:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r----- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 27 12:57 debug<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:57 in<br>
-rw-r----- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;0 Nov 
27 12:57 out</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/templates:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>-rw-r--r-- &nbsp; &nbsp;1 cgitest 
&nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;407 Dec &nbsp;6 20:30 bounce.txt<br>
-rw-r--r-- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;215 Dec 
&nbsp;6 20:30 confirm_accept.txt<br>
-rw-r--r-- &nbsp; &nbsp;1 cgitest &nbsp;nobody &nbsp; &nbsp; &nbsp; &nbsp;702 Dec 
&nbsp;6 20:33 confirm_request.txt</tt></td>
    </tr>
  </table><br>
  <tt>/etc/tmda-cgi:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>cgitest:XPkY0q/9Uge9I</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters/incoming:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>from-file 
/var/tmda/cgitest/lists/blacklist reject<br>
from-file /var/tmda/cgitest/lists/whitelist accept<br>
from-file /var/tmda/cgitest/lists/confirmed accept</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/filters/outgoing:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>to-file /var/tmda/cgitest/lists/whitelist 
tag envelope dated=10d from bare<br>
to-file /var/tmda/cgitest/lists/confirmed tag envelope dated=10d from bare</tt></td>
    </tr>
  </table><br>
  <tt>/var/tmda/cgitest/templates/confirm_request.txt:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>From.US-ASCII: "%(FULLNAME)s" 
<%(recipient_address)s><br>
Subject.US-ASCII: Please confirm your message<br>
Reply-To.US-ASCII: %(confirm_accept_address)s<br>
BodyCharset: US-ASCII<br>
&nbsp;<br>
This message was created automatically by mail delivery software<br>
(TMDA).<br>
&nbsp;<br>
Your message attached below is being held because the address<br>
<%(confirm_append_address)s> has not been verified.<br>
&nbsp;<br>
To release your message for delivery, please send an empty message<br>
to the following address, surf the following link, or use your<br>
mailer's "Reply" feature.<br>
&nbsp;<br>
 &nbsp; %(confirm_accept_address)s<br>
&nbsp;<br>
 &nbsp; %(confirm_accept_url)s<br>
&nbsp;<br>
This confirmation verifies that your message is legitimate and not<br>
junk-mail. You should only have to confirm your address once.</tt></td>
    </tr>
  </table><br>
  <tt>/etc/tmdarc:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>import Util<br>
&nbsp;<br>
# Allow group access to critical files<br>
ALLOW_MODE_640 = 1<br>
os.umask(0027)<br>
&nbsp;<br>
# Locate important files and directories<br>
DATADIR = "/var/tmda/%s/" % os.environ["USER"]<br>
        CONFIRM_APPEND &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + 
"lists/confirmed"<br>
FILTER_INCOMING &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "filters/incoming"<br>
FILTER_OUTGOING &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "filters/outgoing"<br>
LOGFILE_DEBUG &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;= DATADIR + "logs/debug"<br>
LOGFILE_INCOMING &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "logs/in"<br>
LOGFILE_OUTGOING &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "logs/out"<br>
PENDING_BLACKLIST_APPEND = DATADIR + "lists/blacklist"<br>
PENDING_WHITELIST_APPEND = DATADIR + "lists/whitelist"<br>
TEMPLATE_DIR &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; = DATADIR + "templates/"<br>
&nbsp;<br>
# CGI location<br>
CGI_URL = "http://wolfhome.com/~cgitest/index2.cgi";<br>
<br>
# Define X-Primary-Address key for TMDA-to-TMDA communications<br>
ADDED_HEADERS_CLIENT = { "X-Primary-Address": "[EMAIL PROTECTED]" % \<br>
 &nbsp;(os.environ["USER"], Util.gethostname()) }</tt></td>
    </tr>
  </table><br>
  <tt>~cgitest/.qmail:</tt> 
  <table>
    <tr> 
      <td width="600" bgcolor="#CCCCCC"><tt>|preline /usr/src/tmda/bin/tmda-filter -c 
/var/tmda/cgitest/config<br>
./Maildir/</tt></td>
    </tr>
  </table>
</blockquote>
<p>tmda-cgi was compiled with the following:</p>
<blockquote> 
  <pre>./compile -nc /var/tmda/~/config -t /www/tmda.cgi</pre>
</blockquote>
<p>Use the <tt>./compile -h</tt> for more details on how to use compile.</p>
<hr>
<h2><a name="Pass"></a>Passwords</h2>
<p>tmda-cgi currently authenticate logins against user name &amp; password pairs 
  stored in a password file (or files). tmda-cgi will look in two different places 
  for password file(s), but it (they) must be readable by the CGI.</p>
<p>If you are running in system-wide mode, the password file can be owned by root. 
  If you are running in single-user mode, the password file can be owned by the 
  user who will be running the CGI. If you are running in no-su mode, the file 
  must either be owned by &quot;nobody&quot; (or whatever user your web server 
  is configured to run as) or made globally readable See the table below for a 
  better breakdown of your options.</p>
<p>tmda-cgi first checks for a readable file called <tt>tmda-cgi</tt> in the same 
  directory as the user's configuration file (if that location has been specified, 
  otherwise it will look in <tt>~user/.tmda/tmda-cgi</tt>). It then tries 
<tt>/etc/tmda-cgi</tt> 
  if it can't find a match or cannot read the file. This allows the system 
administrator 
  to keep a list of access passwords while allowing the user to override what 
  the sysadmin has set.</p>
<table border="0" cellpadding="0" cellspacing="0">
  <tr> 
    <td width="35">&nbsp;</td>
    <td width="10">&nbsp;</td>
    <td>&nbsp;</td>
    <td width="10">&nbsp;</td>
    <td colspan="2" align="center" nowrap 
bgcolor="#FFFFCC"><tt>~user/.tmda/tmda-cgi</tt></td>
    <td width="10" align="center" nowrap>&nbsp;</td>
    <td colspan="2" align="center" nowrap bgcolor="#FFFFCC"><tt>/etc/tmda-cgi</tt></td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td width="80" align="center" bgcolor="#FFFFCC">owner</td>
    <td width="90" align="center" bgcolor="#FFFFCC">permissions</td>
    <td align="center">&nbsp;</td>
    <td width="80" align="center" bgcolor="#FFFFCC">owner</td>
    <td width="90" align="center" bgcolor="#FFFFCC">permissions</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td bgcolor="#CCFFFF">system-wide</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">user</td>
    <td align="center" bgcolor="#CCFFCC">600</td>
    <td align="center" bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">root</td>
    <td align="center" bgcolor="#CCFFCC">600</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>single-user</td>
    <td>&nbsp;</td>
    <td align="center" bgcolor="#FFFFCC">user</td>
    <td align="center" bgcolor="#FFFFCC">600</td>
    <td align="center">&nbsp;</td>
    <td colspan="2" align="center" bgcolor="#FFFFCC">n/a</td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td bgcolor="#CCFFFF">no-su</td>
    <td bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">user</td>
    <td align="center" bgcolor="#CCFFCC">644</td>
    <td align="center" bgcolor="#CCFFFF">&nbsp;</td>
    <td align="center" bgcolor="#CCFFCC">root<br>
      nobody </td>
    <td align="center" bgcolor="#CCFFCC">644<br>
      600 </td>
  </tr>
  <tr> 
    <td>&nbsp;</td>
    <td colspan="8" align="center">File owner &amp; permission options</td>
  </tr>
</table>
<p>The password file for tmda-cgi is formatted in much the same way as the password 
  file for tofmipd. In fact, if you are using a password file with tofmipd and 
  you wish to run tmda-cgi in system-wide mode, feel free to make a symbolic link 
  between the two:</p>
<blockquote> 
  <pre> # ln -s /etc/tofmipd /etc/tmda-cgi</pre>
</blockquote>
<p>Password files for tmda-cgi look like:</p>
<blockquote> 
  <pre>&lt;user1&gt;:&lt;password1&gt;
&lt;user2&gt;:&lt;password2&gt;</pre>
</blockquote>
<p>where each item in <tt>&lt;&gt;</tt> is replaced with text.</p>
<p>The difference between this password file and the one for tofmipd is that the 
  file does not need to have <br>
  permissions of 400 or 600. If you, for example, are running in no-su mode, you 
  will have to make your password file group or world readable.</p>
<p>To keep the passwords secure, tmda-cgi will assume all passwords are DES encrypted 
  if the file permissions are anything other than 400 or 600. Plaintext passwords 
  will <i><b>not</b></i> work in such cases.</p>
<p>Additionally, any entry with a blank password field, such as:</p>
<blockquote> 
  <pre>cantlogin:</pre>
</blockquote>
<p>will be prohibited from login, regardless of the file permissions.</p>
<p><tt>contrib/cgi/genpass.py</tt> is provided for encrypted password generation. 
  Output from <tt>genpass.py</tt> can be safely piped with <tt>&gt;</tt> or 
<tt>&gt;&gt;</tt> 
  into a password file. For example:</p>
<blockquote> 
  <pre># contrib/cgi/genpass.py joe &gt;&gt; /etc/tmda-cgi</pre>
</blockquote>
<p> or</p>
<blockquote> 
  <pre>$ contrib/cgi/genpass.py joe &gt; /home/joe/.tmda/tmda-cgi</pre>
</blockquote>
<p>If you encounter difficulties logging in, the problem may be a result of incorrect 
  permissions on your password file(s). To debug this, append a <tt>?debug=1</tt> 
  onto the end of your CGI URL. This will display some diagnostic information 
  if the login fails instead of simply saying &quot;Wrong password. Try 
again.&quot;</p>
<hr>
<h2><a name="Virtual" id="Virtual"></a>Virtual users</h2>
<p>Although planned for future releases, there is no support for virtual users 
  at this time. Each user who plans to use tmda-cgi must have a login record in 
  <tt>/etc/passwd</tt>.</p>
<hr>
<h2><a name="Config"></a>Configuration</h2>
<p>tmda-cgi is configured by a set of parameters in your configuration file(s). 
  All tmda-cgi configuration variables begin with a &quot;<tt>CGI_</tt>&quot; 
  and are described on the <a href="config-vars.html">Configuration Variables</a> 
  page.</p>
<p><em><strong>Note:</strong></em> If you change nothing else, you will have to 
  at least set the value for <a 
href="config-vars.html#CGI_ACTIVE"><tt>CGI_ACTIVE</tt></a>.</p>
<hr>
<h2><a name="Surprise" id="Surprise"></a>Surprises &amp; gotcha's</h2>
<p>This section of the documentation is reserved for functionality and quirks 
  that, although not erroneous, may not be what you expect. Check this list for 
  help if you experience problems with tmda-cgi.</p>
<ol>
  <li>tmda-cgi's whitelist feature does not update the list pointed to by 
configuration 
    variable <tt><a 
href="/config-vars.html#CONFIRM_APPEND">CONFIRM_APPEND</a></tt><tt>.</tt> 
    <p>tmda-cgi uses configuration variable <a 
href="/config-vars.html#PENDING_WHITELIST_APPEND"><tt>PENDING_WHITELIST_APPEND</tt></a>
 
      instead of <tt><a 
href="/config-vars.html#CONFIRM_APPEND">CONFIRM_APPEND</a>.</tt> 
      To use the whitelist feature, you must set <a 
href="/config-vars.html#PENDING_WHITELIST_APPEND"><tt>PENDING_WHITELIST_APPEND</tt></a>
 
      to a list that is handled by your incoming filter.<p></li>
  <li>TMDA requires Python version 2.1 but some flavors of Linux (such as <a 
href="http://redhat.com";>RedHat</a>) 
    come with two different versions of Python installed, one older and one newer. 
    <p>If tmda-cgi tries to run using the wrong version of Python, then you must 
      specify the correct version at compile time. Instead of typing:
    <blockquote>
          <pre>$ ./compile &lt;options&gt;</pre>
        </blockquote>
    <p>Type:</p>
        <blockquote>
          <pre>$ /usr/bin/python2 compile &lt;options&gt;</pre>
        </blockquote>
    <p>(Assuming that your Python 2.1+ can be found at <tt>/usr/bin/python2</tt>.) 
      The compiler will save the correct version of the Python interpreter and 
      use it when tmda-cgi is run.</p>
        </li>
</ol>
<hr>
<h2><a name="Template" id="Template"></a>Templates</h2>
<p>By supplying your own templates (see the <a href="howto-template.html">Template 
  HOWTO</a> for more on customizing your templates) you can use tmda-cgi's URL 
  confirmation feature. This allows you to specify a URL in your confirmation 
  e-mail as an alternative to confirming by e-mail.</p>
<p>To supply a confirmation URL, simply use the <tt>%(confirm_accept_url)s</tt> 
  variable in <tt>confirm_request.txt</tt> as shown in <a 
href="#nosuExample">Centralized 
  no-su setup</a>.</p>
<p><em><strong>Notes:</strong></em></p>
<ul>
  <li>Be sure you set <a href="config-vars.html#CGI_ACTIVE"><tt>CGI_ACTIVE</tt></a>, 
    <a href="config-vars.html#CGI_URL"><tt>CGI_URL</tt></a>, and <a 
href="config-vars.html#TEMPLATE_DIR"><tt>TEMPLATE_DIR</tt></a> 
    before modifying your template! No confirmation e-mails will be sent if you 
    specify a <tt>%(confirm_accept_url)</tt> until these variables are properly 
    configured.<br>
  </li>
  <li>Always test your configuration after making a change to your templates.<br>
  </li>
  <li>Your crypt_key file must be readible by tmda-cgi to use this feature. 
    <p>This is not and issue if you are running in system-wide orf single-user 
      modes, but in no-su mode, you will have to:</p>
  </li>
  <ul>
    <li>Put crypt_key in the CGI's group.</li>
    <li>Assign crypt_key 640 permissions.</li>
    <li>Turn on <a href="config-vars.html#ALLOW_MODE_640">ALLOW_MODE_640</a>.<br>
    </li>
  </ul>
</ul>

</td><!-- end of body cell -->
</tr><!-- end of sidebar/body row -->
</table><!-- end of page table -->
</body></html>

_______________________________________
tmda-cvs mailing list
http://tmda.net/lists/listinfo/tmda-cvs

Reply via email to