Update README and fix sample filter
This commit is contained in:
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Compiled test programs
|
||||||
|
samplefilter
|
||||||
|
samplefilter2
|
||||||
95
README.md
95
README.md
@@ -1,2 +1,95 @@
|
|||||||
# gomilter
|
# gomilter
|
||||||
Go Bindings for libmilter
|
Go Bindings for Sendmail's libmilter
|
||||||
|
|
||||||
|
Tested on Linux and FreeBSD
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
The Sendmail header file libmilter/mfapi.h is required. For Redhat/CentOS, install the sendmail-devel package:
|
||||||
|
```sh
|
||||||
|
yum install sendmail-devel
|
||||||
|
```
|
||||||
|
|
||||||
|
Install the gomilter package:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
go get github.com/leonrbaker/gomilter
|
||||||
|
```
|
||||||
|
|
||||||
|
##Usage
|
||||||
|
|
||||||
|
The milter is implemented in a struct. Start by defining your own struct type and embeding the gomilter MilterRaw struct.
|
||||||
|
|
||||||
|
```go
|
||||||
|
type Mymilter struct {
|
||||||
|
gomilter.MilterRaw // Embed the basic functionality.
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Milter callbacks are added by implementing methods for the struct with matching predefined names.
|
||||||
|
|
||||||
|
### Callbacks
|
||||||
|
|
||||||
|
* Connect
|
||||||
|
* Helo
|
||||||
|
* EnvFrom
|
||||||
|
* EnvRcpt
|
||||||
|
* Header
|
||||||
|
* Eoh
|
||||||
|
* Body
|
||||||
|
* Eom
|
||||||
|
* Abort
|
||||||
|
* Close
|
||||||
|
|
||||||
|
Not all the callbacks need to be defined. The callbacks are explained on the milter.org site. Unfortunately the milter.org site has been shut down but it is still on [web.archive.org](http://web.archive.org/web/20150510034154/https://www.milter.org/developers/api/index)
|
||||||
|
|
||||||
|
### Message Modification Functions
|
||||||
|
|
||||||
|
* AddHeader
|
||||||
|
* ChgHeader
|
||||||
|
* InsHeader
|
||||||
|
* ChgFrom
|
||||||
|
* AddRcpt
|
||||||
|
* AddRcpt_Par
|
||||||
|
* DelRcpt
|
||||||
|
* ReplaceBody
|
||||||
|
|
||||||
|
### Other Message Handling Functions
|
||||||
|
* progress
|
||||||
|
|
||||||
|
### Startup
|
||||||
|
|
||||||
|
The Socket field of the milter struct must be set. For example:
|
||||||
|
```go
|
||||||
|
mymilter.Socket = "unix:/var/gomilter/socket"
|
||||||
|
```
|
||||||
|
|
||||||
|
Control is handed over to the libmilter smfi_main function by calling the Run method and passing it a pointer to your milter struct
|
||||||
|
```go
|
||||||
|
gomilter.Run(mymilter)
|
||||||
|
```
|
||||||
|
|
||||||
|
The milter has a Stop method which calls the libmilter smfi_stop function.
|
||||||
|
|
||||||
|
### Private Data
|
||||||
|
|
||||||
|
libmilter is able to store private data for a connection. This data can be accessed from other functions and callbacks for the same connection. You can pass a pointer to any data structure to SetPriv. The data is retrieved with GetPriv
|
||||||
|
```go
|
||||||
|
t := T{1, 2, 3}
|
||||||
|
m.SetPriv(ctx, &t)
|
||||||
|
```
|
||||||
|
Retrieve the data with
|
||||||
|
```go
|
||||||
|
var t T
|
||||||
|
m.GetPriv(ctx, &t))
|
||||||
|
```
|
||||||
|
|
||||||
|
GetPriv should only be called once. If the private data is needed in another function or callback then call SetPriv again.
|
||||||
|
|
||||||
|
## Sample Programs
|
||||||
|
There are two sample programs included, samplefilter.go and samplefilter2.go
|
||||||
|
|
||||||
|
##Other Libraries
|
||||||
|
|
||||||
|
A usefull MIME parsing library is [go.enmime](https://github.com/jhillyerd/go.enmime)
|
||||||
|
|
||||||
|
|||||||
@@ -40,7 +40,8 @@ func main() {
|
|||||||
mymilter := new(Mymilter)
|
mymilter := new(Mymilter)
|
||||||
mymilter.FilterName = "TestFilter"
|
mymilter.FilterName = "TestFilter"
|
||||||
mymilter.Debug = true
|
mymilter.Debug = true
|
||||||
mymilter.Flags = gomilter.AddHdrs | gomilter.AddRcpt
|
mymilter.Flags = gomilter.ADDHDRS | gomilter.ADDRCPT
|
||||||
|
mymilter.Socket = "unix:/var/milterattachcheck/socket"
|
||||||
|
|
||||||
// Start Milter
|
// Start Milter
|
||||||
gomilter.Run(mymilter)
|
gomilter.Run(mymilter)
|
||||||
|
|||||||
Reference in New Issue
Block a user