aboutsummaryrefslogtreecommitdiffstats
path: root/security/nessus/Makefile
blob: 0757a38f28cae99c08acb2d359fabca9977faf2f (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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# New ports collection makefile for:    nessus
# Date created:     1 May 1999
# Whom:         Anders Nordby <anders@fix.no>
#
# $FreeBSD$
#
# If you want to only have the command-line client even if gtk is already
# installed define one of these:
#  WITHOUT_GNOME
#  WITHOUT_GTK
#  WITHOUT_NESSUS_GTK

PORTNAME=   nessus
PORTVERSION=    2.2.3
CATEGORIES= security
MASTER_SITES=   ftp://ftp.nessus.org/pub/nessus/nessus-${PORTVERSION}/src/ \
        ftp://ftp.gwdg.de/pub/linux/misc/nessus/nessus-${PORTVERSION}/src/ \
        http://ftp.gwdg.de/pub/linux/misc/nessus/nessus-${PORTVERSION}/src/ \
        ftp://sunsite.cnlab-switch.ch/mirror/nessus/nessus-${PORTVERSION}/src/ \
        ftp://ftp.au.nessus.org/pub/nessus/nessus-${PORTVERSION}/src/ \
        ftp://ftp.ayamura.org/pub/nessus/nessus-${PORTVERSION}/src/
DISTNAME=   nessus-core-${PORTVERSION}

MAINTAINER= udo.schweigert@siemens.com
COMMENT=    A security scanner: looks for vulnerabilities in a given network

CONFLICTS=  nessus-devel-[0-9]* nessus-devel-gtk-[0-9]* \
        nessus-devel-gtk2-[0-9]*
LIB_DEPENDS=    nasl.4:${PORTSDIR}/security/nessus-libnasl

DIST_SUBDIR=    nessus
WRKSRC=     ${WRKDIR}/nessus-core
PKGDEINSTALL=   ${WRKDIR}/pkg-deinstall.sh

USE_LIBTOOL_VER=    13
USE_REINPLACE=  YES
USE_RC_SUBR=    YES
WANT_GNOME= yes
.if defined(WITHOUT_NESSUS_GTK) || defined(WITHOUT_GTK)
WITHOUT_GNOME=  yes
.endif

.include <bsd.port.pre.mk>

.if ${HAVE_GNOME:Mgtk20}!=""
USE_GNOME+= gtk20
PKGNAMESUFFIX=  -gtk2
.elif ${HAVE_GNOME:Mgtk12}!=""
USE_GNOME+= gtk12
PKGNAMESUFFIX=  -gtk
.else
CONFIGURE_ARGS+=--disable-gtk
.endif

MAN1=       nessus.1 nessus-mkrand.1 nessus-mkcert-client.1
MAN8=       nessusd.8 nessus-adduser.8 nessus-mkcert.8 nessus-rmuser.8

RC_SCRIPTS_SUB= PREFIX=${PREFIX} \
        RC_SUBR=${RC_SUBR}

SED_SCRIPT= -e 's,%%PKGNAME%%,${PKGNAME},g' \
        -e 's,%%PREFIX%%,${PREFIX},g'

post-build:
.for script in pkg-deinstall
    @${SED} ${SED_SCRIPT} ${SCRIPTDIR}/${script} > ${WRKDIR}/${script}.sh
.endfor

post-install:
    @${SED} ${RC_SCRIPTS_SUB:S/$/!g/:S/^/ -e s!%%/:S/=/%%!/} \
        ${FILESDIR}/nessusd.sh > ${PREFIX}/etc/rc.d/nessusd.sh
    @${CHMOD} +x ${PREFIX}/etc/rc.d/nessusd.sh
    @${SED} -e 's;\$${PREFIX};${PREFIX};' ${FILESDIR}/nessusd.conf \
        > ${PREFIX}/etc/nessus/nessusd.conf.dist
    @${SED} -e 's;\$${PREFIX};${PREFIX};' ${FILESDIR}/nessusd.rules \
        > ${PREFIX}/etc/nessus/nessusd.rules.dist
    @${CHMOD} 644 ${PREFIX}/etc/nessus/nessusd.conf.dist \
        ${PREFIX}/etc/nessus/nessusd.rules.dist
    @if [ ! -f ${PREFIX}/etc/nessus/nessusd.conf ]; then \
        ${CP} -p ${PREFIX}/etc/nessus/nessusd.conf.dist \
            ${PREFIX}/etc/nessus/nessusd.conf; \
    fi
    @if [ ! -f ${PREFIX}/etc/nessus/nessusd.rules ]; then \
        ${CP} -p ${PREFIX}/etc/nessus/nessusd.rules.dist \
            ${PREFIX}/etc/nessus/nessusd.rules; \
    fi
    @${SETENV} ${SCRIPTS_ENV} ${SH} ${SCRIPTDIR}/move_nessus
.if ! exists(${PREFIX}/var/CA/serverkey.pem)
    @${ECHO} ""
    @${ECHO} "**************************************************************************"   
    @${ECHO} "To create and install a new certificate, type \"make cert\""
    @${ECHO} "**************************************************************************"
    @${ECHO} ""
.endif
    @${CAT} ${PKGMESSAGE}

cert:
    @${ECHO} ""
    @${ECHO} "**************************************************************************"
    @${ECHO} "The new certificate will be saved into ${PREFIX}/var/CA/serverkey.pem"
    @${ECHO} "**************************************************************************"
    @${ECHO} ""
    ${PREFIX}/sbin/nessus-mkcert

.include <bsd.port.post.mk>