| author | Tomas Zeman <tzeman@volny.cz> |
| Fri, 04 May 2012 20:24:29 +0200 | |
| changeset 138 | ef1e8be95300 |
| parent 113 | 37d7b9252b13 |
| permissions | -rw-r--r-- |
| 32 | 1 |
ospam |
| 1 | 2 |
|
3 |
diff --git a/source/custom/ospam/FrugalBuild b/source/custom/ospam/FrugalBuild |
|
4 |
new file mode 100644 |
|
5 |
--- /dev/null |
|
6 |
+++ b/source/custom/ospam/FrugalBuild |
|
7 |
@@ -0,0 +1,25 @@ |
|
8 |
+# Maintainer: Tomas Zeman <tzeman@volny.cz> |
|
9 |
+ |
|
10 |
+pkgname=ospam |
|
11 |
+pkgver=0.01 |
|
|
113
37d7b9252b13
ospam.patch: folded w/ upgrade-0.9-ospam.patch
Tomas Zeman <tzeman@volny.cz>
parents:
32
diff
changeset
|
12 |
+pkgrel=2 |
|
37d7b9252b13
ospam.patch: folded w/ upgrade-0.9-ospam.patch
Tomas Zeman <tzeman@volny.cz>
parents:
32
diff
changeset
|
13 |
+pkgdesc="system-wide anti-spam solution for qmail and vmailmgr" |
| 1 | 14 |
+url="http://omail.omnis.ch/ospam/" |
15 |
+archs=(i686) |
|
16 |
+up2date="lynx $url?M=D -dump -nolist|grep 'tar.gz'|head -1|sed -e 's/.*$pkgname-\(.*\)\.tar\.gz.*$/\1/'" |
|
17 |
+depends=('spamassassin' 'clamav' 'conn-tools' 'qmail' 'perl-dbd-mysql' 'mess822')
|
|
18 |
+backup=(etc/ospam/ospam-dotqmail etc/ospam/spamclam) |
|
19 |
+source=($url/$pkgname-$pkgver.tar.gz spamclam ospam.patch) |
|
20 |
+sha1sums=('7a47fbdedddc16d8fe04ca400daee00a962408da' \
|
|
21 |
+ 'acd24f2b9daa5f15e2e9360050d9ea0bd96c1dbc' \ |
|
22 |
+ '7e8aa8d7d8b9a0ac5e88e5304a0f69d4b267a784') |
|
23 |
+ |
|
24 |
+build() {
|
|
25 |
+ Fcd |
|
26 |
+ Fpatchall |
|
27 |
+ Fmkdir /usr/bin /usr/share/$pkgname /etc/$pkgname |
|
28 |
+ Finstall 755 $pkgname-$pkgver/ospam-dotqmail.pl /usr/bin/ospam-dotqmail |
|
29 |
+ Finstall 755 spamclam /usr/bin |
|
30 |
+ Finstall 644 $pkgname-$pkgver/sql/nospam.sql /usr/share/ospam/dbschema.sql |
|
31 |
+} |
|
32 |
+# vim: ft=sh |
|
33 |
diff --git a/source/custom/ospam/ospam.patch b/source/custom/ospam/ospam.patch |
|
34 |
new file mode 100644 |
|
35 |
--- /dev/null |
|
36 |
+++ b/source/custom/ospam/ospam.patch |
|
37 |
@@ -0,0 +1,82 @@ |
|
38 |
+diff -u ospam-0.01.orig/ospam-dotqmail.pl ospam-0.01/ospam-dotqmail.pl |
|
39 |
+--- ospam-0.01.orig/ospam-dotqmail.pl 2003-05-04 04:21:26.000000000 +0200 |
|
40 |
++++ ospam-0.01/ospam-dotqmail.pl 2007-12-16 00:13:19.000000000 +0100 |
|
41 |
+@@ -32,50 +32,52 @@ |
|
42 |
+ |
|
43 |
+ # SETUP: |
|
44 |
+ |
|
45 |
+-my $debug = 1; |
|
46 |
++our $debug = 1; |
|
47 |
+ |
|
48 |
+ # emails: |
|
49 |
+ |
|
50 |
+-my $debug_bcc_mail = ''; # keep empty after testing |
|
51 |
+-my $admin_mail = ''; # for error notices |
|
52 |
+-my $mail_sender = 'oSpam system <ospam@your-domain-here.ext>'; |
|
53 |
++our $debug_bcc_mail = ''; # keep empty after testing |
|
54 |
++our $admin_mail = ''; # for error notices |
|
55 |
++our $mail_sender = 'oSpam system <ospam@your-domain-here.ext>'; |
|
56 |
+ |
|
57 |
+ # database: |
|
58 |
+ |
|
59 |
+-my $db_username = "nospam"; |
|
60 |
+-my $db_password = "*********"; |
|
61 |
+-my $db_hostname = "localhost"; |
|
62 |
+-my $db_database = "nospam"; |
|
63 |
++our $db_username = "nospam"; |
|
64 |
++our $db_password = "*********"; |
|
65 |
++our $db_hostname = "localhost"; |
|
66 |
++our $db_database = "nospam"; |
|
67 |
+ |
|
68 |
+-my $tb_userpref = "userpref"; # SA sql table |
|
69 |
+-my $tb_dotqmail = "dotqmail"; # ospam data |
|
70 |
++our $tb_userpref = "userpref"; # SA sql table |
|
71 |
++our $tb_dotqmail = "dotqmail"; # ospam data |
|
72 |
+ |
|
73 |
+ # file & cmd path: |
|
74 |
+ |
|
75 |
+-my $cmd_preline = "/var/qmail/bin/preline"; |
|
76 |
+-my $cmd_spamc = "/usr/bin/spamc"; |
|
77 |
+-my $cmd_vdeliver = "/usr/local/bin/vdeliver"; |
|
78 |
+-my $cmd_filepipe = "/usr/local/nospam/filepipe"; |
|
79 |
+-my $cmd_ifspamh = "/usr/local/nospam/ifspamh"; |
|
80 |
+-my $spamc_options = "-f"; |
|
81 |
+-my $cmd_md5sum = "/usr/bin/md5sum"; |
|
82 |
+-my $cmd_chown = "/bin/chown"; |
|
83 |
+-my $cmd_chmod = "/bin/chmod"; |
|
84 |
+-my $cmd_sendmail = "/usr/sbin/sendmail"; |
|
85 |
+-my $sendmail_opt = "-oem -oi -t"; |
|
86 |
++our $cmd_preline = "/var/qmail/bin/preline"; |
|
87 |
++our $cmd_spamc = "/usr/bin/spamc"; |
|
88 |
++our $cmd_vdeliver = "/usr/local/bin/vdeliver"; |
|
89 |
++our $cmd_filepipe = "/usr/local/nospam/filepipe"; |
|
90 |
++our $cmd_ifspamh = "/usr/local/nospam/ifspamh"; |
|
91 |
++our $spamc_options = "-f"; |
|
92 |
++our $cmd_md5sum = "/usr/bin/md5sum"; |
|
93 |
++our $cmd_chown = "/bin/chown"; |
|
94 |
++our $cmd_chmod = "/bin/chmod"; |
|
95 |
++our $cmd_sendmail = "/usr/sbin/sendmail"; |
|
96 |
++our $sendmail_opt = "-oem -oi -t"; |
|
97 |
+ |
|
98 |
+ # qmail setup: |
|
99 |
+ |
|
100 |
+-my $cfg_virtualdomains = "/var/qmail/control/virtualdomains"; |
|
101 |
+-my $cfg_rcpthosts = "/var/qmail/control/rcpthosts"; |
|
102 |
+-my $dot_qmail_prefix = ".qmail-"; |
|
103 |
++our $cfg_virtualdomains = "/var/qmail/control/virtualdomains"; |
|
104 |
++our $cfg_rcpthosts = "/var/qmail/control/rcpthosts"; |
|
105 |
++our $dot_qmail_prefix = ".qmail-"; |
|
106 |
+ |
|
107 |
+ # internal values |
|
108 |
+ |
|
109 |
+ my $version = 1; # integer |
|
110 |
+ my $internal_version = 1000; # incrementing this number will force re-generation of all .qmail-files |
|
111 |
+ |
|
112 |
++my $cfg_file = "/etc/ospam/ospam-dotqmail"; |
|
113 |
+ |
|
114 |
++do $cfg_file if (-f $cfg_file); |
|
115 |
+ |
|
116 |
+ ################################################# |
|
117 |
+ |
|
118 |
+Only in ospam-0.01: ospam-dotqmail.pl~ |
|
119 |
+Common subdirectories: ospam-0.01.orig/sql and ospam-0.01/sql |
|
| 32 | 120 |
diff --git a/source/custom/ospam/spamclam b/source/custom/ospam/spamclam |
121 |
new file mode 100755 |
|
122 |
--- /dev/null |
|
123 |
+++ b/source/custom/ospam/spamclam |
|
124 |
@@ -0,0 +1,97 @@ |
|
125 |
+#!/bin/sh |
|
126 |
+ |
|
127 |
+[ -f /etc/ospam/spamclam ] && . /etc/ospam/spamclam |
|
128 |
+ |
|
129 |
+# CONFIG |
|
130 |
+SPAMC=${SPAMC:-/usr/bin/spamc}
|
|
131 |
+CLAMDSCAN=${CLAMDSCAN:-/usr/bin/clamdscan}
|
|
132 |
+FORWARDBIN=${FORWARDBIN:-/var/qmail/bin/forward}
|
|
133 |
+M822FIELD=${M822FIELD:-/usr/bin/822field}
|
|
134 |
+FILEPIPE=${FILEPIPE:-/command/seekablepipe} #/usr/bin/filepipe
|
|
135 |
+VDELIVER=${VDELIVER:-/usr/bin/vdeliver}
|
|
136 |
+TMP=${TMP:-.}
|
|
137 |
+ |
|
138 |
+[ -x $SPAMC -a -x $CLAMDSCAN -a -x $FORWARDBIN -a -x $M822FIELD ] || {
|
|
139 |
+ echo -e "$0: Required programs do not exist" |
|
140 |
+ cat | $FILEPIPE $VDELIVER |
|
141 |
+ exit 0 |
|
142 |
+} |
|
143 |
+ |
|
144 |
+ADDR_QUARANTINE="$1" |
|
145 |
+DELIVER_VIRUS="$2" |
|
146 |
+ADDR_SPAM="$3" |
|
147 |
+DELIVER_SPAM="$4" |
|
148 |
+MAILUSER="$5" |
|
149 |
+ |
|
150 |
+if [ -z "$ADDR_QUARANTINE" -o -z "$ADDR_SPAM" -o -z "$DELIVER_VIRUS" -o -z "$DELIVER_SPAM" ]; then |
|
151 |
+ echo -e "Usage: $0 quarantine_address deliver_virus_to_recipient(0/1) spam_address deliver_spam_to_recipient(0/1) [mailuser address]" |
|
152 |
+ echo -e "address may be: _ignore_ -> checking of that feature is ignored" |
|
153 |
+ echo -e " _noaddr_ -> if infected, do not forward" |
|
154 |
+ cat |
|
155 |
+ exit 0 |
|
156 |
+fi |
|
157 |
+ |
|
158 |
+MAILFILE="$TMP/mail.tmp.$$" |
|
159 |
+ |
|
160 |
+cat >$MAILFILE |
|
161 |
+ |
|
162 |
+VIRUS=0 |
|
163 |
+SPAM=0 |
|
164 |
+STATUS=0 |
|
165 |
+ |
|
166 |
+spam_flags="" |
|
167 |
+ |
|
168 |
+if [ "$ADDR_QUARANTINE" != "_ignore_" ]; then |
|
169 |
+ virus=`$CLAMDSCAN --disable-summary --stdout $MAILFILE | grep FOUND` |
|
170 |
+ if [ ! "$virus" = "" ]; then |
|
171 |
+ VIRUS=1 |
|
172 |
+ cat $MAILFILE | sed -e 's/^Subject:/Subject: [virus]/' > $MAILFILE.1 |
|
173 |
+ fi |
|
174 |
+fi |
|
175 |
+ |
|
176 |
+if [ $VIRUS -eq 0 -a "$ADDR_SPAM" != "_ignore_" ]; then |
|
177 |
+ if [ ! -z $MAILUSER ]; then |
|
178 |
+ spam_flags="-u $MAILUSER" |
|
179 |
+ fi |
|
180 |
+ $SPAMC $spam_flags < $MAILFILE > $MAILFILE.1 |
|
181 |
+ isspam=`$M822FIELD X-Spam-Flag < $MAILFILE.1 | grep YES | wc -l` |
|
182 |
+ if [ $isspam -ne 0 ]; then |
|
183 |
+ SPAM=1 |
|
184 |
+ fi |
|
185 |
+fi |
|
186 |
+ |
|
187 |
+ |
|
188 |
+if [ $VIRUS -eq 1 ]; then |
|
189 |
+ STATUS=99 |
|
190 |
+ if [ $DELIVER_VIRUS -eq 1 ]; then |
|
191 |
+ cat $MAILFILE.1 | $FILEPIPE $VDELIVER |
|
192 |
+ fi |
|
193 |
+ if [ "$ADDR_QUARANTINE" != "_noaddr_" ]; then |
|
194 |
+ $FORWARDBIN $ADDR_QUARANTINE < $MAILFILE.1 |
|
195 |
+ if [ $? -ne 0 ]; then |
|
196 |
+ STATUS=111 |
|
197 |
+ fi |
|
198 |
+ fi |
|
199 |
+else |
|
200 |
+if [ $SPAM -eq 1 ]; then |
|
201 |
+ STATUS=99 |
|
202 |
+ if [ $DELIVER_SPAM -eq 1 ]; then |
|
203 |
+ cat $MAILFILE.1 | $FILEPIPE $VDELIVER |
|
204 |
+ fi |
|
205 |
+ if [ "$ADDR_SPAM" != "_noaddr_" ]; then |
|
206 |
+ $FORWARDBIN $ADDR_SPAM < $MAILFILE.1 |
|
207 |
+ if [ $? -ne 0 ]; then |
|
208 |
+ STATUS=111 |
|
209 |
+ fi |
|
210 |
+ fi |
|
211 |
+fi |
|
212 |
+fi |
|
213 |
+ |
|
214 |
+if [ $VIRUS -eq 0 -a $SPAM -eq 0 ]; then |
|
215 |
+ cat $MAILFILE | $FILEPIPE $VDELIVER |
|
216 |
+fi |
|
217 |
+ |
|
218 |
+rm -f $MAILFILE $MAILFILE.1 |
|
219 |
+ |
|
220 |
+exit $STATUS |
|
221 |
+ |