aboutsummaryrefslogtreecommitdiffstats
path: root/Mk/Scripts/check-vulnerable.sh
blob: ecac738103dc014f95247bc80d47c5496b9c4979 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#!/bin/sh
# $FreeBSD$
#
# MAINTAINER: portmgr@FreeBSD.org

set -e

. "${dp_SCRIPTSDIR}/functions.sh"

validate_env dp_ECHO_MSG dp_PKG_BIN dp_PORTNAME dp_PKGNAME

[ -n "${DEBUG_MK_SCRIPTS}" -o -n "${DEBUG_MK_SCRIPTS_CHECK_VULNERABLE}" ] && set -x

set -u

# If the package is pkg, disable these checks, it fails while
# upgrading when pkg is not there.
# FIXME: check is this is still true
if [ "${dp_PORTNAME}" = "pkg" ]; then
    exit 0
fi

if [ ! -x "${dp_PKG_BIN}" ]; then
    exit 0
fi

vlist=$(${dp_PKG_BIN} audit "${dp_PKGNAME}" || :)

if [ "${vlist}" != "0 problem(s) in the installed packages found." ]; then
    ${dp_ECHO_MSG} "===>  ${dp_PKGNAME} has known vulnerabilities:"
    ${dp_ECHO_MSG} "$vlist"
    ${dp_ECHO_MSG} "=> Please update your ports tree and try again."
    ${dp_ECHO_MSG} "=> Note: Vulnerable ports are marked as such even if there is no update available."
    ${dp_ECHO_MSG} "=> If you wish to ignore this vulnerability rebuild with 'make DISABLE_VULNERABILITIES=yes'"
    exit 1
fi