blob: 1b82dceac2fd73969cc75496e0d03c3a7aa78d57 [file] [log] [blame]
Andrew Geisslereff27472021-10-29 15:35:00 -05001DESCRIPTION = "strongSwan is an OpenSource IPsec implementation for the \
2Linux operating system."
3SUMMARY = "strongSwan is an OpenSource IPsec implementation"
4HOMEPAGE = "http://www.strongswan.org"
5SECTION = "net"
Andrew Geissler9aee5002022-03-30 16:27:02 +00006LICENSE = "GPL-2.0-only"
Andrew Geisslereff27472021-10-29 15:35:00 -05007LIC_FILES_CHKSUM = "file://COPYING;md5=b234ee4d69f5fce4486a80fdaf4a4263"
Andrew Geissler595f6302022-01-24 19:11:47 +00008DEPENDS = "flex-native flex bison-native"
9DEPENDS:append = "${@bb.utils.contains('DISTRO_FEATURES', 'tpm2', ' tpm2-tss', '', d)}"
Andrew Geisslereff27472021-10-29 15:35:00 -050010
11SRC_URI = "http://download.strongswan.org/strongswan-${PV}.tar.bz2 \
Andrew Geissler615f2f12022-07-15 14:00:58 -050012 file://0001-enum-Fix-compiler-warning.patch \
Andrew Geisslereff27472021-10-29 15:35:00 -050013 "
14
Andrew Geissler615f2f12022-07-15 14:00:58 -050015SRC_URI[sha256sum] = "91d0978ac448912759b85452d8ff0d578aafd4507aaf4f1c1719f9d0c7318ab7"
Andrew Geisslereff27472021-10-29 15:35:00 -050016
17UPSTREAM_CHECK_REGEX = "strongswan-(?P<pver>\d+(\.\d+)+)\.tar"
18
19EXTRA_OECONF = " \
20 --without-lib-prefix \
21 --with-dev-headers=${includedir}/strongswan \
22"
23
24EXTRA_OECONF += "${@bb.utils.contains('DISTRO_FEATURES', 'systemd', '--with-systemdsystemunitdir=${systemd_unitdir}/system/', '--without-systemdsystemunitdir', d)}"
25
Andrew Geissler595f6302022-01-24 19:11:47 +000026PACKAGECONFIG ?= "curl gmp openssl sqlite3 swanctl curve25519\
Andrew Geisslereff27472021-10-29 15:35:00 -050027 ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'systemd-charon', 'charon', d)} \
Andrew Geissler595f6302022-01-24 19:11:47 +000028 ${@bb.utils.contains('DISTRO_FEATURES', 'tpm2', 'tpm2', '', d)} \
29 ${@bb.utils.contains('DISTRO_FEATURES', 'ima', 'tnc-imc imc-hcd imc-os imc-scanner imc-attestation', '', d)} \
30 ${@bb.utils.contains('DISTRO_FEATURES', 'ima', 'tnc-imv imv-hcd imv-os imv-scanner imv-attestation', '', d)} \
Andrew Geisslereff27472021-10-29 15:35:00 -050031"
Andrew Geissler595f6302022-01-24 19:11:47 +000032
Andrew Geisslereff27472021-10-29 15:35:00 -050033PACKAGECONFIG[aesni] = "--enable-aesni,--disable-aesni,,${PN}-plugin-aesni"
34PACKAGECONFIG[bfd] = "--enable-bfd-backtraces,--disable-bfd-backtraces,binutils"
35PACKAGECONFIG[charon] = "--enable-charon,--disable-charon,"
36PACKAGECONFIG[curl] = "--enable-curl,--disable-curl,curl,${PN}-plugin-curl"
37PACKAGECONFIG[eap-identity] = "--enable-eap-identity,--disable-eap-identity,,${PN}-plugin-eap-identity"
38PACKAGECONFIG[eap-mschapv2] = "--enable-eap-mschapv2,--disable-eap-mschapv2,,${PN}-plugin-eap-mschapv2"
39PACKAGECONFIG[gmp] = "--enable-gmp,--disable-gmp,gmp,${PN}-plugin-gmp"
40PACKAGECONFIG[ldap] = "--enable-ldap,--disable-ldap,openldap,${PN}-plugin-ldap"
41PACKAGECONFIG[mysql] = "--enable-mysql,--disable-mysql,mysql5,${PN}-plugin-mysql"
42PACKAGECONFIG[openssl] = "--enable-openssl,--disable-openssl,openssl,${PN}-plugin-openssl"
43PACKAGECONFIG[scep] = "--enable-scepclient,--disable-scepclient,"
44PACKAGECONFIG[soup] = "--enable-soup,--disable-soup,libsoup-2.4,${PN}-plugin-soup"
45PACKAGECONFIG[sqlite3] = "--enable-sqlite,--disable-sqlite,sqlite3,${PN}-plugin-sqlite"
46PACKAGECONFIG[stroke] = "--enable-stroke,--disable-stroke,,${PN}-plugin-stroke"
47PACKAGECONFIG[swanctl] = "--enable-swanctl,--disable-swanctl,,libgcc"
Andrew Geissler595f6302022-01-24 19:11:47 +000048PACKAGECONFIG[curve25519] = "--enable-curve25519,--disable-curve25519,, ${PN}-plugin-curve25519"
Andrew Geisslereff27472021-10-29 15:35:00 -050049
50# requires swanctl
51PACKAGECONFIG[systemd-charon] = "--enable-systemd,--disable-systemd,systemd,"
52
Andrew Geissler595f6302022-01-24 19:11:47 +000053# tpm needs meta-tpm layer
54PACKAGECONFIG[tpm2] = "--enable-tpm,--disable-tpm,,${PN}-plugin-tpm"
55
56
57# integraty configuration needs meta-integraty
58#imc
59PACKAGECONFIG[tnc-imc] = "--enable-tnc-imc,--disable-tnc-imc,, ${PN}-plugin-tnc-imc ${PN}-plugin-tnc-tnccs"
60PACKAGECONFIG[imc-test] = "--enable-imc-test,--disable-imc-test,,"
61PACKAGECONFIG[imc-scanner] = "--enable-imc-scanner,--disable-imc-scanner,,"
62PACKAGECONFIG[imc-os] = "--enable-imc-os,--disable-imc-os,,"
63PACKAGECONFIG[imc-attestation] = "--enable-imc-attestation,--disable-imc-attestation,,"
64PACKAGECONFIG[imc-swima] = "--enable-imc-swima, --disable-imc-swima, json-c,"
65PACKAGECONFIG[imc-hcd] = "--enable-imc-hcd, --disable-imc-hcd,,"
66
67#imv set
68PACKAGECONFIG[tnc-imv] = "--enable-tnc-imv,--disable-tnc-imv,, ${PN}-plugin-tnc-imv ${PN}-plugin-tnc-tnccs"
69PACKAGECONFIG[imv-test] = "--enable-imv-test,--disable-imv-test,,"
70PACKAGECONFIG[imv-scanner] = "--enable-imv-scanner,--disable-imv-scanner,,"
71PACKAGECONFIG[imv-os] = "--enable-imv-os,--disable-imv-os,,"
72PACKAGECONFIG[imv-attestation] = "--enable-imv-attestation,--disable-imv-attestation,,"
73PACKAGECONFIG[imv-swima] = "--enable-imv-swima, --disable-imv-swima, json-c,"
74PACKAGECONFIG[imv-hcd] = "--enable-imv-hcd, --disable-imv-hcd,,"
75
76PACKAGECONFIG[tnc-ifmap] = "--enable-tnc-ifmap,--disable-tnc-ifmap, libxml2, ${PN}-plugin-tnc-ifmap"
77PACKAGECONFIG[tnc-pdp] = "--enable-tnc-pdp,--disable-tnc-pdp,, ${PN}-plugin-tnc-pdp"
78
79PACKAGECONFIG[tnccs-11] = "--enable-tnccs-11,--disable-tnccs-11,libxml2, ${PN}-plugin-tnccs-11"
80PACKAGECONFIG[tnccs-20] = "--enable-tnccs-20,--disable-tnccs-20,, ${PN}-plugin-tnccs-20"
81PACKAGECONFIG[tnccs-dynamic] = "--enable-tnccs-dynamic,--disable-tnccs-dynamic,,${PN}-plugin-tnccs-dynamic"
82
Andrew Geisslereff27472021-10-29 15:35:00 -050083inherit autotools systemd pkgconfig
84
Andrew Geissler595f6302022-01-24 19:11:47 +000085RRECOMMENDS:${PN} = "kernel-module-ah4 \
86 kernel-module-esp4 \
87 kernel-module-xfrm-user \
88 "
Andrew Geisslereff27472021-10-29 15:35:00 -050089
90FILES:${PN} += "${libdir}/ipsec/lib*${SOLIBS}"
91FILES:${PN}-dbg += "${bindir}/.debug ${sbindir}/.debug ${libdir}/ipsec/.debug ${libexecdir}/ipsec/.debug"
92FILES:${PN}-dev += "${libdir}/ipsec/lib*${SOLIBSDEV} ${libdir}/ipsec/*.la ${libdir}/ipsec/include/config.h"
93FILES:${PN}-staticdev += "${libdir}/ipsec/*.a"
94
95CONFFILES:${PN} = "${sysconfdir}/*.conf ${sysconfdir}/ipsec.d/*.conf ${sysconfdir}/strongswan.d/*.conf"
96
97PACKAGES += "${PN}-plugins"
98ALLOW_EMPTY:${PN}-plugins = "1"
99
Andrew Geissler595f6302022-01-24 19:11:47 +0000100PACKAGE_BEFORE_PN = "${PN}-imcvs ${PN}-imcvs-dbg"
101ALLOW_EMPTY:${PN}-imcvs = "1"
102
103FILES:${PN}-imcvs = "${libdir}/ipsec/imcvs/*.so"
104FILES:${PN}-imcvs-dbg += "${libdir}/ipsec/imcvs/.debug"
105
Andrew Geisslereff27472021-10-29 15:35:00 -0500106PACKAGES_DYNAMIC += "^${PN}-plugin-.*$"
107NOAUTOPACKAGEDEBUG = "1"
108
109python split_strongswan_plugins () {
110 sysconfdir = d.expand('${sysconfdir}/strongswan.d/charon')
111 libdir = d.expand('${libdir}/ipsec/plugins')
112 dbglibdir = os.path.join(libdir, '.debug')
113
114 def add_plugin_conf(f, pkg, file_regex, output_pattern, modulename):
115 dvar = d.getVar('PKGD')
116 oldfiles = d.getVar('CONFFILES:' + pkg)
117 newfile = '/' + os.path.relpath(f, dvar)
118
119 if not oldfiles:
120 d.setVar('CONFFILES:' + pkg, newfile)
121 else:
122 d.setVar('CONFFILES:' + pkg, oldfiles + " " + newfile)
123
Andrew Geissler7e0e3c02022-02-25 20:34:39 +0000124 split_packages = do_split_packages(d, libdir, r'libstrongswan-(.*)\.so', '${PN}-plugin-%s', 'strongSwan %s plugin', prepend=True)
125 do_split_packages(d, sysconfdir, r'(.*)\.conf', '${PN}-plugin-%s', 'strongSwan %s plugin', prepend=True, hook=add_plugin_conf)
Andrew Geisslereff27472021-10-29 15:35:00 -0500126
Andrew Geissler7e0e3c02022-02-25 20:34:39 +0000127 split_dbg_packages = do_split_packages(d, dbglibdir, r'libstrongswan-(.*)\.so', '${PN}-plugin-%s-dbg', 'strongSwan %s plugin - Debugging files', prepend=True, extra_depends='${PN}-dbg')
128 split_dev_packages = do_split_packages(d, libdir, r'libstrongswan-(.*)\.la', '${PN}-plugin-%s-dev', 'strongSwan %s plugin - Development files', prepend=True, extra_depends='${PN}-dev')
129 split_staticdev_packages = do_split_packages(d, libdir, r'libstrongswan-(.*)\.a', '${PN}-plugin-%s-staticdev', 'strongSwan %s plugin - Development files (Static Libraries)', prepend=True, extra_depends='${PN}-staticdev')
Andrew Geisslereff27472021-10-29 15:35:00 -0500130
131 if split_packages:
132 pn = d.getVar('PN')
133 d.setVar('RRECOMMENDS:' + pn + '-plugins', ' '.join(split_packages))
134 d.appendVar('RRECOMMENDS:' + pn + '-dbg', ' ' + ' '.join(split_dbg_packages))
135 d.appendVar('RRECOMMENDS:' + pn + '-dev', ' ' + ' '.join(split_dev_packages))
136 d.appendVar('RRECOMMENDS:' + pn + '-staticdev', ' ' + ' '.join(split_staticdev_packages))
137}
138
139PACKAGESPLITFUNCS:prepend = "split_strongswan_plugins "
140
141# Install some default plugins based on default strongSwan ./configure options
142# See https://wiki.strongswan.org/projects/strongswan/wiki/Pluginlist
143RDEPENDS:${PN} += "\
144 ${PN}-plugin-aes \
145 ${PN}-plugin-attr \
146 ${PN}-plugin-cmac \
147 ${PN}-plugin-constraints \
148 ${PN}-plugin-des \
149 ${PN}-plugin-dnskey \
150 ${PN}-plugin-hmac \
151 ${PN}-plugin-kernel-netlink \
152 ${PN}-plugin-md5 \
153 ${PN}-plugin-nonce \
154 ${PN}-plugin-pem \
155 ${PN}-plugin-pgp \
156 ${PN}-plugin-pkcs1 \
157 ${PN}-plugin-pkcs7 \
158 ${PN}-plugin-pkcs8 \
159 ${PN}-plugin-pkcs12 \
160 ${PN}-plugin-pubkey \
161 ${PN}-plugin-random \
162 ${PN}-plugin-rc2 \
163 ${PN}-plugin-resolve \
164 ${PN}-plugin-revocation \
165 ${PN}-plugin-sha1 \
166 ${PN}-plugin-sha2 \
167 ${PN}-plugin-socket-default \
168 ${PN}-plugin-sshkey \
169 ${PN}-plugin-updown \
170 ${PN}-plugin-vici \
171 ${PN}-plugin-x509 \
172 ${PN}-plugin-xauth-generic \
173 ${PN}-plugin-xcbc \
Andrew Geisslereff27472021-10-29 15:35:00 -0500174 "
175
176RPROVIDES:${PN} += "${PN}-systemd"
177RREPLACES:${PN} += "${PN}-systemd"
178RCONFLICTS:${PN} += "${PN}-systemd"
179
180# The deprecated legacy 'strongswan-starter' service should only be used when charon and
181# stroke are enabled. When swanctl is in use, 'strongswan.service' is needed.
182# See: https://wiki.strongswan.org/projects/strongswan/wiki/Charon-systemd
183SYSTEMD_SERVICE:${PN} = " \
184 ${@bb.utils.contains('PACKAGECONFIG', 'swanctl', '${BPN}.service', '', d)} \
185 ${@bb.utils.contains('PACKAGECONFIG', 'charon', '${BPN}-starter.service', '', d)} \
186"