]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blob - lfs/logwatch
Diverse Fixes.
[people/pmueller/ipfire-2.x.git] / lfs / logwatch
1 ###############################################################################
2 # This file is part of the IPCop Firewall. #
3 # #
4 # IPCop is free software; you can redistribute it and/or modify #
5 # it under the terms of the GNU General Public License as published by #
6 # the Free Software Foundation; either version 2 of the License, or #
7 # (at your option) any later version. #
8 # #
9 # IPCop is distributed in the hope that it will be useful, #
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
12 # GNU General Public License for more details. #
13 # #
14 # You should have received a copy of the GNU General Public License #
15 # along with IPCop; if not, write to the Free Software #
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #
17 # #
18 # Makefiles are based on LFSMake, which is #
19 # Copyright (C) 2002 Rod Roard <rod@sunsetsystems.com> #
20 # #
21 ###############################################################################
22
23 ###############################################################################
24 # Definitions
25 ###############################################################################
26
27 include Config
28
29 VER = 7.3.1
30
31 THISAPP = logwatch_$(VER)
32 DL_FILE = $(THISAPP).orig.tar.gz
33 DL_FROM = $(URL_IPFIRE)
34 DIR_APP = $(DIR_SRC)/logwatch-$(VER)
35 TARGET = $(DIR_INFO)/$(THISAPP)
36
37 ###############################################################################
38 # Top-level Rules
39 ###############################################################################
40
41 objects = $(DL_FILE)
42
43 $(DL_FILE) = $(DL_FROM)/$(DL_FILE)
44
45 $(DL_FILE)_MD5 = c43a783e791ad4851f44c6af98d71b38
46
47 install : $(TARGET)
48
49 check : $(patsubst %,$(DIR_CHK)/%,$(objects))
50
51 download :$(patsubst %,$(DIR_DL)/%,$(objects))
52
53 md5 : $(subst %,%_MD5,$(objects))
54
55 ###############################################################################
56 # Downloading, checking, md5sum
57 ###############################################################################
58
59 $(patsubst %,$(DIR_CHK)/%,$(objects)) :
60 @$(CHECK)
61
62 $(patsubst %,$(DIR_DL)/%,$(objects)) :
63 @$(LOAD)
64
65 $(subst %,%_MD5,$(objects)) :
66 @$(MD5)
67
68 ###############################################################################
69 # Installation Details
70 ###############################################################################
71
72 $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
73 @$(PREBUILD)
74 @rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar zxf $(DIR_DL)/$(DL_FILE)
75 -mkdir -p /etc/log.d /var/log/logwatch
76 chown logwatch:nobody /var/log/logwatch
77 cd $(DIR_APP) && cp -Rf conf scripts lib /etc/log.d
78 cd $(DIR_APP) && install -m 0755 scripts/logwatch.pl /etc/log.d/scripts/logwatch.pl
79 cd $(DIR_APP) && install -m 0644 logwatch.8 /usr/share/man/man8
80 sed -i 's/^Print = .*$$/Print = Yes/' /etc/log.d/conf/logwatch.conf
81 # comment out line with unused example
82 sed -i '/-zz-network/s/Service/#Service/' /etc/log.d/conf/logwatch.conf
83 # fix typo in output
84 sed -i '/MB transfered/s/transfered/transferred/' /etc/log.d/scripts/services/http
85
86 # Strip out some filters for services we don't run - no point wasting log keeping them
87 # cron filter don't support fcron
88 # final selection for remaining files is in rootfile
89 UNNEEDED="afpd amavis arpwatch audit automount autorpm cisco \
90 courier emerge exim extreme-networks ftpd-messages ftpd-xferlog \
91 identd in.qpopper ipop3d mountd named netopia netscreen \
92 oidentd pam_pwdb portsentry pound pureftp \
93 pureftpd qmail rt314 sendmail-largeboxes shaperd smartd \
94 sonicwall stunnel tac_acc up2date vpopmail vsftpd windows xferlog yum zz-fortune" && \
95 for i in $$UNNEEDED ; do \
96 rm -f /etc/log.d/{conf,scripts}/services/$$i{,.conf} /etc/log.d/conf/logfiles/$$i.conf; \
97 done
98 rm -rf /etc/log.d/scripts/logfiles
99 cp -f $(DIR_SRC)/config/logwatch/dialup /etc/log.d/scripts/services/dialup
100 cp -f $(DIR_SRC)/config/logwatch/dialup.conf /etc/log.d/conf/services/dialup.conf
101
102 sed -i 's/df -h/df -h -x rootfs/' /etc/log.d/scripts/services/zz-disk_space
103 for i in `find /etc/log.d -type f`; do \
104 sed -i 's/perl -w/perl/' $$i; \
105 done
106 # The httpd log checker script considers any request containing the word
107 # null to be an exploit attempt, reverse this behaviour as we have a
108 # null.gif
109 sed -i -e "/ 'null',/d" /etc/log.d/scripts/services/http
110 chmod -R 755 /etc/log.d
111 @rm -rf $(DIR_APP)
112 @$(POSTBUILD)