aboutsummaryrefslogtreecommitdiffstats
path: root/security/openvpn/Makefile
blob: 516ccf0e902ade885910fd029871f50b186c72a5 (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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# Created by: Matthias Andree <matthias.andree@gmx.de>
# $FreeBSD$

PORTNAME=   openvpn
DISTVERSION=    2.2.2
CATEGORIES= security net
# MASTER_SITES points to hosts in distinct data centers,
# so just one MASTER_SITES entry should be OK.
MASTER_SITES=   http://swupdate.openvpn.net/community/releases/ \
        ${MASTER_SITE_LOCAL:S,$,mandree/,}

MAINTAINER= mandree@FreeBSD.org
COMMENT=    Secure IP/Ethernet tunnel daemon

LICENSE=    GPLv2

CONFLICTS_INSTALL=  openvpn-devel-[0-9]* openvpn-2.0* openvpn-beta-[0-9]*

GNU_CONFIGURE=  yes
USE_OPENSSL=    yes
USE_XZ=     yes
CONFIGURE_ARGS= --with-lzo-lib=${LOCALBASE}/lib \
        --with-lzo-headers=${LOCALBASE}/include

OPTIONS_DEFINE= PW_SAVE PKCS11
PW_SAVE_DESC=   Interactive passwords may be read from a file
PKCS11_DESC=    Use security/pkcs11-helper

.include <bsd.port.options.mk>

.if ${PORT_OPTIONS:MDOCS}
INSTALL_TARGET= install
.else
INSTALL_TARGET= install-exec install-man
.endif

INSTALL_TARGET+=    mandir=${MANPREFIX}/man
MAN8=       openvpn.8

USE_RC_SUBR=    openvpn
USE_LDCONFIG=   ${PREFIX}/lib

SUB_FILES=  pkg-message
SUB_LIST+=  OSVERSION=${OSVERSION}

.include <bsd.port.pre.mk>

.ifdef (LOG_OPENVPN)
CFLAGS+=    -DLOG_OPENVPN=${LOG_OPENVPN}
.endif

LIB_DEPENDS+=   lzo2:${PORTSDIR}/archivers/lzo2

.if ${PORT_OPTIONS:MPW_SAVE}
CONFIGURE_ARGS+=    --enable-password-save
.else
CONFIGURE_ARGS+=    --disable-password-save
.endif

.if ${PORT_OPTIONS:MPKCS11}
LIB_DEPENDS+=   pkcs11-helper:${PORTSDIR}/security/pkcs11-helper
.else
CONFIGURE_ARGS+=    --disable-pkcs11
.endif

post-patch:
    @${FIND} ${WRKSRC}/easy-rsa/?.0 -type f \
        -exec ${REINPLACE_CMD} -e 's;#!/bin/bash;#!/bin/sh;' \
                   -e 's,source ./vars,. ./vars,' \{\} +
    @${FIND} ${WRKSRC}/plugin -name Makefile \
        -exec ${REINPLACE_CMD} -e 's;gcc;${CC};g' '{}' +
    @${FIND} ${WRKSRC} \( -name \*.orig -o -name \*.bak \) -delete

pre-configure:
.ifdef (LOG_OPENVPN)
    @${ECHO} "Building with LOG_OPENVPN=${LOG_OPENVPN}"
.else
    @${ECHO} ""
    @${ECHO} "You may use the following build options:"
    @${ECHO} ""
    @${ECHO} "      LOG_OPENVPN={Valid syslog facility, default LOG_DAEMON}"
    @${ECHO} "      EXAMPLE:  make LOG_OPENVPN=LOG_DAEMON"
    @${ECHO} ""
.endif

post-build:
    cd ${WRKSRC}/plugin/down-root && ${SETENV} ${MAKE_ENV} ${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${_MAKE_JOBS} ${MAKE_ARGS}
    cd ${WRKSRC}/plugin/auth-pam && ${CC} ${CPPFLAGS} -I../.. -DDLOPEN_PAM=0 ${CFLAGS} -fPIC -shared -Wl,-soname,openvpn-auth-pam.so -o openvpn-auth-pam.so auth-pam.c pamdl.c -lc -lpam
    @# self-tests here
.if !defined(WITHOUT_CHECK)
    @${ECHO} ; ${ECHO} "### Note that you can skip these lengthy selftests with WITHOUT_CHECK=yes ###" ; ${ECHO}
    cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${_MAKE_JOBS} ${MAKE_ARGS} check
.endif

post-install:
    ${MKDIR} ${PREFIX}/lib
    ${INSTALL_PROGRAM} ${WRKSRC}/plugin/down-root/openvpn-down-root.so ${PREFIX}/lib/
    ${INSTALL_PROGRAM} ${WRKSRC}/plugin/auth-pam/openvpn-auth-pam.so ${PREFIX}/lib/
.if ${PORT_OPTIONS:MDOCS}
    ${MKDIR} ${DOCSDIR}
    ${INSTALL_DATA} ${WRKSRC}/plugin/down-root/README ${DOCSDIR}/README.openvpn-down-root
    ${INSTALL_DATA} ${WRKSRC}/plugin/auth-pam/README ${DOCSDIR}/README.openvpn-auth-pam
.for docs in AUTHORS COPYING COPYRIGHT.GPL ChangeLog INSTALL \
    PORTS README
    ${INSTALL_DATA} ${WRKSRC}/${docs} ${DOCSDIR}/
.endfor
.for dir in easy-rsa easy-rsa/1.0 easy-rsa/2.0 sample-config-files
    ${MKDIR} ${DOCSDIR}/${dir}
    ${FIND} ${WRKSRC}/${dir}/ -maxdepth 1 -type f -exec ${INSTALL_DATA} \{\} ${DOCSDIR}/${dir} \;
.endfor
.for dir in sample-scripts
    ${MKDIR} ${DOCSDIR}/${dir}
    ${FIND} ${WRKSRC}/${dir}/ -maxdepth 1 -type f -exec ${INSTALL_SCRIPT} \{\} ${DOCSDIR}/${dir} \;
.endfor
.else
    -@${RMDIR} ${DOCSDIR}
.endif
    @${CAT} ${PKGMESSAGE}

.include <bsd.port.post.mk>