Merge remote-tracking branch 'origin/next' into fifteen
[people/pmueller/ipfire-2.x.git] / lfs / strongswan
1 ###############################################################################
2 #                                                                             #
3 # IPFire.org - A linux based firewall                                         #
4 # Copyright (C) 2007-2013  IPFire Team  <info@ipfire.org>                     #
5 #                                                                             #
6 # This program is free software: you can redistribute it and/or modify        #
7 # it under the terms of the GNU General Public License as published by        #
8 # the Free Software Foundation, either version 3 of the License, or           #
9 # (at your option) any later version.                                         #
10 #                                                                             #
11 # This program is distributed in the hope that it will be useful,             #
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of              #
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the               #
14 # GNU General Public License for more details.                                #
15 #                                                                             #
16 # You should have received a copy of the GNU General Public License           #
17 # along with this program.  If not, see <http://www.gnu.org/licenses/>.       #
18 #                                                                             #
19 ###############################################################################
20
21 ###############################################################################
22 # Definitions
23 ###############################################################################
24
25 include Config
26
27 VER        = 5.1.1
28
29 THISAPP    = strongswan-$(VER)
30 DL_FILE    = $(THISAPP).tar.bz2
31 DL_FROM    = $(URL_IPFIRE)
32 DIR_APP    = $(DIR_SRC)/strongswan-$(VER)
33 TARGET     = $(DIR_INFO)/$(THISAPP)
34
35 ifeq "$(MACHINE)" "i586"
36         CONFIGURE_OPTIONS = \
37                 --enable-padlock \
38                 --enable-rdrand
39 else
40         CONFIGURE_OPTIONS = \
41                 --disable-padlock \
42                 --disable-rdrand
43 endif
44
45 ###############################################################################
46 # Top-level Rules
47 ###############################################################################
48
49 objects = $(DL_FILE)
50
51 $(DL_FILE) = $(DL_FROM)/$(DL_FILE)
52
53 $(DL_FILE)_MD5 = e3af3d493d22286be3cd794533a8966a
54
55 install : $(TARGET)
56
57 check : $(patsubst %,$(DIR_CHK)/%,$(objects))
58
59 download :$(patsubst %,$(DIR_DL)/%,$(objects))
60
61 md5 : $(subst %,%_MD5,$(objects))
62
63 ###############################################################################
64 # Downloading, checking, md5sum
65 ###############################################################################
66
67 $(patsubst %,$(DIR_CHK)/%,$(objects)) :
68         @$(CHECK)
69
70 $(patsubst %,$(DIR_DL)/%,$(objects)) :
71         @$(LOAD)
72
73 $(subst %,%_MD5,$(objects)) :
74         @$(MD5)
75
76 ###############################################################################
77 # Installation Details
78 ###############################################################################
79
80 $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
81         @$(PREBUILD)
82         @rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar axf $(DIR_DL)/$(DL_FILE)
83         cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/strongswan-5.0.2_ipfire.patch
84         cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/strongswan-5.1.1-delay-dpd.patch
85
86         cd $(DIR_APP) && [ -x "configure" ] || ./autogen.sh
87         cd $(DIR_APP) && ./configure \
88                 --prefix="/usr" \
89                 --sysconfdir="/etc" \
90                 --enable-curl \
91                 --enable-openssl \
92                 --enable-xauth-eap \
93                 --enable-eap-radius \
94                 --enable-eap-tls \
95                 --enable-eap-ttls \
96                 --enable-eap-peap \
97                 --enable-eap-mschapv2 \
98                 --enable-eap-identity \
99                 --enable-unity \
100                 $(CONFIGURE_OPTIONS)
101
102         cd $(DIR_APP) && make $(MAKETUNING)
103         cd $(DIR_APP) && make install
104
105         # Remove all library files we don't want or need.
106         rm -vf /usr/lib/ipsec/plugins/*.{,l}a
107
108         -rm -rfv /etc/rc*.d/*ipsec
109         cd $(DIR_SRC) && cp src/initscripts/init.d/ipsec /etc/rc.d/init.d/ipsec
110         rm -f /etc/ipsec.conf /etc/ipsec.secrets
111         ln -sf $(CONFIG_ROOT)/vpn/ipsec.conf /etc/ipsec.conf
112         ln -sf $(CONFIG_ROOT)/vpn/ipsec.secrets /etc/ipsec.secrets
113
114         rm -rf /etc/ipsec.d/{cacerts,certs,crls}
115         ln -sf $(CONFIG_ROOT)/ca    /etc/ipsec.d/cacerts
116         ln -sf $(CONFIG_ROOT)/certs /etc/ipsec.d/certs
117         ln -sf $(CONFIG_ROOT)/crls  /etc/ipsec.d/crls
118
119         @rm -rf $(DIR_APP)
120         @$(POSTBUILD)