From mboxrd@z Thu Jan 1 00:00:00 1970 From: Michael Tremer To: development@lists.ipfire.org Subject: Re: [PATCH] strongswan: Update to version 5.9.12 Date: Wed, 22 Nov 2023 10:47:43 +0000 Message-ID: In-Reply-To: <20231121223744.3459555-1-adolf.belka@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============7088411709261672656==" List-Id: --===============7088411709261672656== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Reviewed-by: Michael Tremer I am back :) > On 21 Nov 2023, at 22:37, Adolf Belka wrote: >=20 > - Update from version 5.9.11 to 5.9.12 > - Update of rootfile > - Changelog > 5.9.12 > Vulnerabilities > Fixed a vulnerability in charon-tkm (the TKM-backed version of the charo= n IKE > daemon) related to processing DH public values that can lead to a buffer > overflow and potentially remote code execution. This vulnerability has = been > registered as CVE-2023-41913. Please refer to our blog for details. > New Feature Additions > The new pki --ocsp command produces OCSP responses based on certificate = status > information provided by implementations of the new ocsp_responder_t int= erface > (#1958). > Two sources are currently available, the openxpki plugin that directly > accesses the OpenXPKI database and the command's --index argument, which > reads certificate status information from OpenSSL-style index.txt files > (multiple CAs are supported concurrently). > The new cert-enroll script handles the initial enrollment of an X.509 ho= st > certificate with a PKI server via the EST or SCEP protocols. > Run as a systemd timer or via a crontab entry, the script checks the > expiration date of the host certificate daily. When a given deadline is > reached, the host certificate is automatically renewed via EST or SCEP > re-enrollment based on the possession of the old private key and the > matching certificate. > Added a global option (charon.reject_trusted_end_entity) to prevent peers > from authenticating with certificates that are locally trusted, in > particular, our own local certificate, which safeguards against acciden= tal > reuse of certificates on multiple peers. As the name suggests, all trus= ted > end-entity certificates are rejected if enabled, so peer certificates c= an't > be configured explicitly anymore (e.g. via remote.certs in swanctl.conf= ). > The --priv argument for charon-cmd allows the use of any type of private= key > (previously, only RSA keys were supported). > The openssl plugin now supports the nameConstraints extension in X.509 > certificates (#1990). > Support for nameConstraints of type iPAddress are now supported by the x= 509, > openssl and constraints plugins (#1991). > Support for encoding subjectAlternativeName extensions of type > uniformResourceIdentifier in X.509 certificates has been added via the = uri: > prefix (e.g. for URNs, #1983). > Support for password-less PKCS#12 and PKCS#8 files has been added (#1955= ). > Enhancements and Optimizations > Because of a relatively recent NIAP requirement (TD0527, Test 8b), loadi= ng of > certificates with ECDSA keys that explicitly encode the curve parameter= s is > rejected if possible. Explicit encoding is pretty rare to begin with and > e.g. wolfSSL already rejects such keys, by default. All crypto plugins = that > support ECDSA enforce this by rejecting such public keys, except when u= sing > older versions of OpenSSL (< 1.1.1h) or Botan (< 3.2.0) (#1949). > Make the NetworkManager plugin (charon-nm) actually use the XFRM interfa= ce it > creates since 5.9.10. This involves setting interface IDs on SAs and > policies, and installing routes via the interface. To avoid routing loo= ps if > the remote traffic selectors include the VPN server, IKE and ESP packet= s are > marked to bypass the routing table that contains the routes via XFRM > interface (69e0c11). > If available, the plugin now also adopts the interface name configured in > connection.interface-name in a *.nmconnection file as name for the XFRM > interface instead of generating one randomly (e8f8d32). > The resolve plugin tries to maintain the order of DNS servers it install= s via > resolvconf or resolv.conf (6440975, 8238ad4). > The kernel-libipsec plugin now always installs routes to remote networks= even > if no address is found in the local traffic selectors, which allows > forwarding traffic from networks the VPN host is not part of (190d8cb). > Increased the default receive buffer size for Netlink sockets to 8 MiB > (doubled by the kernel to account for overhead) and simplified the > configuration (no need for a separate option to force overriding rmem_m= ax). > It's now also set for event sockets, which previously could cause issue= s on > hosts with e.g. lots of route changes (#1757). > When issuing certificates, the subjectKeyIdentifier of the issuing > certificate, if available, is now copied as authorityKeyIdentifier, ins= tead > of always generating a SHA-1 hash of the issuer's subjectPublicKey > (#1992, 6941dcb). > Explicitly request permission to display notifications on Android 13+ > (ddf84c1), also enabled hardware acceleration for the Android-specific > OpenSSL build. > Fixes > Fixed issues while reestablishing multiple CHILD_SAs (e.g. after a DPD > timeout) that could cause a reqid to get assigned to multiple CHILD_SAs= with > unrelated traffic selectors (#1855). > Fixed an issue in watcher_t with handling errors on sockets (e.g. if the > receive buffer is full), which caused an infinite loop if poll() only > signaled POLLERR as event (#1757). > Fixed an issue in the IKE_SA_INIT tracking code that was added with 5.9.= 6, > which did not correctly untrack invalid messages with non-zero message = IDs > or SPIs (0b47357). > Fixed a regression introduced with 5.9.8 when handling IKE redirects dur= ing > IKE_AUTH (595fa07). > Fixed adding the XFRMA_REPLAY_ESN_VAL attribute twice when updating SAs = in > the kernel-netlink plugin, which prevented MOBIKE updates if a large > anti-replay window was used (#1967). > Fixed a race condition in the kernel-pfroute plugin when adding virtual = IPs > if the TUN device is activated after the address was already added > internally, which caused the installed route not to go via TUN device in > order to force the virtual IP as source address (#1807). > Fixed an issue in libtls that could cause the wrong ECDH group to get > instantiated (b5e4bf4). > Fixed the encoding of the CHILD_SA_NOT_FOUND notify if a CHILD_SA is not > found during rekeying. It was previously empty, now contains the SPI and > sets the protocol to the values received in the REKEY_SA notify (849c2c= 9). > Fixed a possible issue with MOBIKE in the Android client on certain devi= ces > (#1691). > For Developers > The new ocsp_responder_t interface can be implemented to provide certifi= cate > status information to the pki --ocsp command. Responders can be > (un-)registered via the ocsp_responders_t instance at lib->ocsp. > For the watcher_t component, WATCHER_EXCEPT has been removed as there is= no > way to explicitly listen for errors on sockets and poll() actually can > return POLLERR for any FD and it might even be the only signaled event > (which caused an infinite loop previously). Now we simply notify the > registered callbacks. The error is then reported by e.g. recvfrom(), wh= ich > was already the case before if POLLERR was returned together with > e.g. POLLIN. > The reqids allocated for CHILD_SAs (including trap policies) via > kernel_interface_t::alloc_reqid() are now refcounted. When recreating a > CHILD_SA, a reference to the reqid can be requested via > child_sa_t::get_reqid_ref(). If another reference is required afterward= s, > one can be acquired directly via kernel_interface_t::ref_reqid(). Each > reference has to be released via kernel_interface_t::release_reqid(), w= hose > interface was simplified. > The testing environment is now based on Debian 12 (bookworm), by default. > Also, when copying files to guests, the guest-specific files are now co= pied > after the default files, which allows overriding files per guest (fixes= an > issue with winnetou's /etc/fstab and mounting the test results). > Refer to the 5.9.12 milestone for a list of all closed issues and pull requ= ests. >=20 > Signed-off-by: Adolf Belka > --- > config/rootfiles/common/strongswan | 1 + > lfs/strongswan | 4 ++-- > 2 files changed, 3 insertions(+), 2 deletions(-) >=20 > diff --git a/config/rootfiles/common/strongswan b/config/rootfiles/common/s= trongswan > index 22adf24b4..a5f256e02 100644 > --- a/config/rootfiles/common/strongswan > +++ b/config/rootfiles/common/strongswan > @@ -181,6 +181,7 @@ usr/sbin/swanctl > #usr/share/man/man1/pki---gen.1 > #usr/share/man/man1/pki---issue.1 > #usr/share/man/man1/pki---keyid.1 > +#usr/share/man/man1/pki---ocsp.1 > #usr/share/man/man1/pki---pkcs7.1 > #usr/share/man/man1/pki---print.1 > #usr/share/man/man1/pki---pub.1 > diff --git a/lfs/strongswan b/lfs/strongswan > index 357283b15..9496d05dd 100644 > --- a/lfs/strongswan > +++ b/lfs/strongswan > @@ -24,7 +24,7 @@ >=20 > include Config >=20 > -VER =3D 5.9.11 > +VER =3D 5.9.12 >=20 > THISAPP =3D strongswan-$(VER) > DL_FILE =3D $(THISAPP).tar.bz2 > @@ -40,7 +40,7 @@ objects =3D $(DL_FILE) >=20 > $(DL_FILE) =3D $(DL_FROM)/$(DL_FILE) >=20 > -$(DL_FILE)_BLAKE2 =3D e8e84d79d1530b9a968ce8429fec0e7b3fcf19b75fdbd4371a38= 763d8564d5b37d012769006330b5c94cff3e914acb1b1a3e2829749effb8c35f9e5d775be491 > +$(DL_FILE)_BLAKE2 =3D 40f80162970152bca028a9af6b37c4c6e2ef38e75f88b92bf03f= 18641dadacbc574441e74cd0c7abb49ce4c15d9b82301aa90cb07c4fd223bf83163ebfbc2381 >=20 > install : $(TARGET) >=20 > --=20 > 2.42.1 >=20 --===============7088411709261672656==--