periodic/security: Add check for pkgsrc vulnerabilities
[dragonfly.git] / etc / periodic / security / 670.pkgsrcaudit
1 #!/bin/sh -
2 #
3 # Copyright (c) 2010  The DragonFly Project
4 # All rights reserved.
5 #
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions
8 # are met:
9 # 1. Redistributions of source code must retain the above copyright
10 #    notice, this list of conditions and the following disclaimer.
11 # 2. Redistributions in binary form must reproduce the above copyright
12 #    notice, this list of conditions and the following disclaimer in the
13 #    documentation and/or other materials provided with the distribution.
14 #
15 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 # ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 # SUCH DAMAGE.
26 #
27
28 # If there is a global system configuration file, suck it in.
29 #
30 if [ -r /etc/defaults/periodic.conf ]
31 then
32     . /etc/defaults/periodic.conf
33     source_periodic_confs
34 fi
35
36 pkgdb_dir=${pkgdb_dir:-/var/db/pkg}
37
38 if pkg_info -K ${pkgdb_dir} -q -E '*'; then
39         case "$daily_status_pkgsrc_fetch_vulnerabilities" in
40           [Yy][Ee][Ss])
41                 echo ""
42                 echo 'Fetching package vulnerabilities database:'
43                 pkg_admin -K ${pkgdb_dir} fetch-pkg-vulnerabilities -su
44                 rc0=$?
45                 ;;
46         *) rc0=0;
47         esac
48         case "$daily_status_pkgsrc_audit_enable" in
49           [Yy][Ee][Ss])
50                 echo ""
51                 echo 'Checking pkgsrc packages for vulnerabilities:'
52                 pkg_admin -K ${pkgdb_dir} audit
53                 rc1=$?
54                 ;;
55         *) rc1=0;
56         esac
57         case "$daily_status_pkgsrc_check_signatures" in
58           [Yy][Ee][Ss])
59                 echo ""
60                 echo 'Checking pkgsrc file signatures:'
61                 pkg_admin -K ${pkgdb_dir} check
62                 rc2=$?
63                 ;;
64         *) rc2=0
65         esac
66 fi
67 if [ $rc0 -gt 0 ] || [ $rc1 -gt 0 ] || [ $rc2 -gt 0 ]; then
68         rc=1
69 fi
70 exit "$rc"