xref: /freebsd/contrib/sendmail/libmilter/docs/api.html (revision 3ff369fed2a08f32dda232c10470b949bef9489f)
1<html>
2<head><title>Milter API</title></head>
3<body>
4<h1>Milter API</h1>
5
6<h2>Contents</h2>
7<ul>
8    <li>Library Control Functions
9    <li>Data Access Functions
10    <li>Message Modification Functions
11    <li>Callbacks
12</ul>
13
14<h2>Library Control Functions</h2>
15
16Before handing control to libmilter (by calling <a
17href="smfi_main.html">smfi_main</a>), a filter may call the following
18functions to set libmilter parameters.  In particular, the filter must
19call <a href="smfi_register.html">smfi_register</a> to register its
20callbacks.  Each function will return either MI_SUCCESS or MI_FAILURE to
21indicate the status of the operation.
22<p>
23None of these functions communicate with the MTA.  All alter the
24library's state, some of which is communicated to the MTA inside <a
25href="smfi_main.html">smfi_main</a>.
26<p>
27<table border="1" cellspacing=0 cellpadding=2><tr bgcolor="#dddddd"><th>Function</th><th>Description</th></tr>
28
29<tr><td><a href="smfi_register.html">smfi_register</a></td><td>Register a filter.</td></tr>
30
31<tr><td><a href="smfi_setconn.html">smfi_setconn</a></td><td>Specify socket to use.</td></tr>
32
33<tr><td><a href="smfi_settimeout.html">smfi_settimeout</a></td><td>Set timeout.</td></tr>
34
35<tr><td><a href="smfi_main.html">smfi_main</a></td><td>Hand control to libmilter.</td></tr>
36
37</table>
38
39<h2>Data Access Functions</h2>
40
41The following functions may be called from within the filter-defined callbacks
42to access information about the current connection or message.
43<p>
44<table border="1" cellspacing=0 cellpadding=2><tr bgcolor="#dddddd"><th>Function</th><th>Description</th></tr>
45<tr><td><a href="smfi_getsymval.html">smfi_getsymval</a></td><td>Return the value
46of a symbol.</td></tr>
47
48<tr><td><a href="smfi_getpriv.html">smfi_getpriv</a></td><td>Get the private data
49pointer.</td></tr>
50
51<tr><td><a href="smfi_setpriv.html">smfi_setpriv</a></td><td>Set the private data
52pointer.</td></tr>
53
54<tr><td><a href="smfi_setreply.html">smfi_setreply</a></td><td>Set the specific
55reply code to be used.</td></tr>
56
57</table>
58
59<h2>Message Modification Functions</h2>
60
61The following functions change a message's contents and attributes.
62<b>They may only be called in <a href="xxfi_eom.html">xxfi_eom</a></b>.
63All of these functions may invoke additional communication with the MTA.
64They will return either MI_SUCCESS or MI_FAILURE to indicate the status of
65the operation.
66
67<p>
68A filter must have set the appropriate flag (listed below) in the
69description passed to <a href="smfi_register.html">smfi_register</a>
70to call any message modification function.  Failure to do so will
71cause the MTA to treat a call to the function as a failure of the
72filter, terminating its connection.
73
74<p>
75Note that the status returned indicates only whether or not the
76filter's message was successfully sent to the MTA, not whether or not
77the MTA performed the requested operation.  For example, <a
78href="smfi_addheader.html">smfi_addheader</a>, when called with an
79illegal header name, will return MI_SUCCESS even though the MTA may
80later refuse to add the illegal header.
81<p>
82<table border="1" cellspacing=0 cellpadding=2><tr bgcolor="#dddddd"><th>Function</th><th>Description</th><th>SMFIF_* flag</tr>
83<tr><td><a href="smfi_addheader.html">smfi_addheader</a></td><td>Add a header to
84the message.</td><td>SMFIF_ADDHDRS</td></tr>
85
86<tr><td><a href="smfi_chgheader.html">smfi_chgheader</a></td><td>Change or delete a header.</td><td>SMFIF_CHGHDRS</td></tr>
87
88<tr><td><a href="smfi_addrcpt.html">smfi_addrcpt</a></td><td>Add a recipient to
89the envelope.</td><td>SMFIF_ADDRCPT</td></tr>
90
91<tr><td><a href="smfi_delrcpt.html">smfi_delrcpt</a></td><td>Delete a recipient
92from the envelope.</td><td>SMFIF_DELRCPT</td></tr>
93
94<tr><td><a href="smfi_replacebody.html">smfi_replacebody</a></td><td>Replace the
95body of the message.</td><td>SMFIF_CHGBODY</td></tr>
96
97</table>
98
99<h2>Callbacks</h2>
100
101The filter should implement one or more of the following callbacks,
102which are registered via <a href="smfi_register.html">smfi_register</a>:
103<p>
104<table border="1" cellspacing=0 cellpadding=2><tr bgcolor="#dddddd"><th>Function</th><th>Description</th></tr>
105
106<tr><td><a href="xxfi_connect.html">xxfi_connect</a></td><td>connection info</td></tr>
107
108<tr><td><a href="xxfi_helo.html">xxfi_helo</a></td><td>SMTP HELO/EHLO command</td></tr>
109
110<tr><td><a href="xxfi_envfrom.html">xxfi_envfrom</a></td><td>envelope sender</td></tr>
111
112<tr><td><a href="xxfi_envrcpt.html">xxfi_envrcpt</a></td><td>envelope recipient</td></tr>
113
114<tr><td><a href="xxfi_header.html">xxfi_header</a></td><td>header</td></tr>
115
116<tr><td><a href="xxfi_eoh.html">xxfi_eoh</a></td><td>end of header</td></tr>
117
118<tr><td><a href="xxfi_body.html">xxfi_body</a></td><td>body block</td></tr>
119
120<tr><td><a href="xxfi_eom.html">xxfi_eom</a></td><td>end of message</td></tr>
121
122<tr><td><a href="xxfi_abort.html">xxfi_abort</a></td><td>message aborted</td></tr>
123
124<tr><td><a href="xxfi_close.html">xxfi_close</a></td><td>connection cleanup</td></tr>
125
126</table>
127
128<p>
129The above callbacks should all return one of the following return values,
130having the indicated meanings.  Any return other than one of the below
131values constitutes an error, and will cause sendmail to terminate its
132connection to the offending filter.
133
134<p><a name="conn-spec"></a>Milter distinguishes between recipient-,
135message-, and connection-oriented routines.  Recipient-oriented
136callbacks may affect the processing of a single message recipient;
137message-oriented callbacks, a single message; connection-oriented
138callbacks, an entire connection (during which multiple messages may be
139delivered to multiple sets of recipients).
140<a href="xxfi_envrcpt.html">xxfi_envrcpt</a> is recipient-oriented.
141<a href="xxfi_connect.html">xxfi_connect</a>,
142<a href="xxfi_helo.html">xxfi_helo</a> and
143<a href="xxfi_close.html">xxfi_close</a> are connection-oriented.  All
144other callbacks are message-oriented.
145
146<p>
147<table border="1" cellspacing=0 cellpadding=2>
148  <tr bgcolor="#dddddd"><th>Return value</th><th>Description</th></tr>
149  <tr valign="top">
150     <td>SMFIS_CONTINUE</td>
151     <td>Continue processing the current connection, message, or recipient.
152     </td>
153  </tr>
154  <tr valign="top">
155     <td>SMFIS_REJECT</td>
156     <td>For a connection-oriented routine, reject this connection; call <a href="xxfi_close.html">xxfi_close</a>.<br>
157        For a message-oriented routine (except
158	<a href="xxfi_eom.html">xxfi_eom</a> or
159        <a href="xxfi_abort.html">xxfi_abort</a>), reject this message.<br>
160	For a recipient-oriented routine, reject the current recipient (but continue processing the current message).
161     </td>
162  </tr>
163  <tr valign="top">
164     <td>SMFIS_DISCARD</td>
165     <td>For a message- or recipient-oriented routine, accept this message, but silently discard it.<br>
166     SMFIS_DISCARD should not be returned by a connection-oriented routine.
167     </td>
168  </tr>
169  <tr valign="top">
170     <td>SMFIS_ACCEPT</td>
171     <td>For a connection-oriented routine, accept this connection without further filter processing; call <a href="xxfi_close.html">xxfi_close</a>.<br>
172         For a message- or recipient-oriented routine, accept this message without further filtering.<br>
173     </td>
174  </tr>
175  <tr valign="top">
176     <td>SMFIS_TEMPFAIL</td>
177     <td>Return a temporary failure, i.e., the corresponding SMTP command will return an appropriate 4xx status code.
178	 For a message-oriented routine (except <a href="xxfi_envfrom.html">xxfi_envfrom</a>), fail for this message. <br>
179	 For a connection-oriented routine, fail for this connection; call <a href="xxfi_close.html">xxfi_close</a>. <br>
180	 For a recipient-oriented routine, only fail for the current recipient; continue message processing.
181     </td>
182  </tr>
183</table>
184
185<hr size="1">
186<font size="-1">
187Copyright (c) 2000 Sendmail, Inc. and its suppliers.
188All rights reserved.
189<br>
190By using this file, you agree to the terms and conditions set
191forth in the <a href="LICENSE.txt">LICENSE</a>.
192</font>
193</body>
194</html>
195