OpenConnect

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search
OpenConnect
Original author(s)David Woodhouse
Developer(s)Daniel Lenski, Nikos Mavrogiannopoulos
Initial releaseMarch 18, 2009 (2009-03-18)[1]
Stable release
8.10 / May 14, 2020; 16 months ago (2020-05-14)[1]
Repository
TypeVPN
License GNU LGPL v2.1[2]
Websitewww.infradead.org/openconnect/

OpenConnect is an open-source software application for connecting to virtual private networks (VPN), which implement secure point-to-point connections.

It was originally written as an open-source replacement for Cisco's proprietary AnyConnect SSL VPN client,[3] which is supported by several Cisco routers. The OpenConnect client added support for Juniper Networks' SSL VPN in version 7.05.[1] A fork then developed support for Palo Alto Networks' GlobalProtect VPN,[4] which was included in the version 8.00 release.[5]

Server[edit]

As of 2013, the OpenConnect project also offers an AnyConnect-compatible server, ocserv,[6] and thus offers a full client-server VPN solution.

OpenConnect and ocserv now implement an extended version of the AnyConnect VPN protocol, which has been proposed as an Internet Standard.[7] Both OpenConnect and ocserv strive to maintain backwards-compatibility with Cisco AnyConnect servers and clients.

Protocols[edit]

Cisco AnyConnect[edit]

Cisco AnyConnect VPNs utilize TLS to authenticate and configure routing, then DTLS to efficiently encrypt and transport the tunneled VPN traffic,[8][9] and can fall back to TLS-based transport where firewalls block UDP-based traffic. The DTLS protocol used by Cisco AnyConnect servers was based on a non-standard, pre-release draft of DTLS 1.0, until support for the DTLS 1.2 standard was added in 2018.[9][10]

OpenConnect's implementation of the AnyConnect protocol is sufficiently complete that some of Cisco's own IP phone devices embed a very old release of OpenConnect[11] (rather than Cisco's own proprietary software) in order to be able to connect to Cisco SSL VPNs.[12][13]

DTLS[edit]

Cisco's proprietary AnyConnect clients and servers were originally built against a patched, 2007 release of OpenSSL 0.9.8f,[14] which implemented a pre-release version of DTLS that was not compatible with DTLS 1.0 as standardized in RFC 4347. Because of this, it was difficult to make OpenConnect implement a Cisco-compatible version of DTLS without linking against OpenSSL.

Explicit support for Cisco's non-standard version of DTLS was included in OpenSSL 0.9.8m (where it is known as DTLS1_BAD_VER) and then GnuTLS 3.2.1 (where it is known as GNUTLS_DTLS0_9).[15] Newer versions of Cisco's AnyConnect clients and servers support DTLS 1.2 in its standardized on-the-wire form (RFC 6347), though they continue to use a non-standard mechanism (based on session resumption) for DTLS key exchange.[7]

Modern versions of OpenConnect can be built to use either the GnuTLS or OpenSSL for TLS, DTLS, and cryptographic primitives.

Other protocols[edit]

The OpenConnect client also implements Juniper, Junos Pulse, and GlobalProtect VPN protocols. These have a very similar structure to the AnyConnect protocol: they authenticate and configure routing over TLS, except that they use ESP for efficient, encrypted transport of tunneled traffic (instead of DTLS), but they too can fall back to TLS-based transport. As of May 2020, support for several PPP-based protocols is in development.[16]

Architecture[edit]

The OpenConnect client is written primarily in C, and it contains much of the infrastructure necessary to add additional VPN protocols operating in a similar flow, and to connect to them via a common user interface:[17]

  • Initial connection to the VPN server via TLS
  • Authentication phase via HTTPS (using HTML forms, client certificates, XML, etc.)
  • Server-provided routing configuration, in a protocol-agnostic format, which can be processed by a vpnc-script
  • Data transport phase via a UDP-based tunnel (DTLS or ESP), with fallback to a TLS-based tunnel

OpenConnect can be built to use either the GnuTLS or OpenSSL libraries for TLS, DTLS and cryptographic primitives.

Platforms[edit]

OpenConnect is available on Solaris, Linux, OpenBSD, FreeBSD, MacOS, and has graphical user interface clients for Windows,[18] GNOME,[19] and KDE.[20] A graphical client for OpenConnect is also available for Android devices,[21] and it has been integrated into router firmware packages such as OpenWrt.[22]

References[edit]

  1. ^ a b c infradead.org - OpenConnect: Changelog.
  2. ^ gitlab.com - OpenConnect: License.
  3. ^ ""Development of OpenConnect was started after a trial of the Cisco client under Linux found it to have many deficiencies …"". Infradead.org. Retrieved 2018-08-13.
  4. ^ dlenski/openconnect on GitHub
  5. ^ "OpenConnect 8.00 release". Lists.infradead.org. Retrieved 2019-01-05.
  6. ^ ocserv home page.
  7. ^ a b N. Mavrogiannopoulos (October 2018). The OpenConnect VPN Protocol Version 1.1. IETF. I-D draft-mavrogiannopoulos-openconnect-02.
  8. ^ Tiso, John; Scholfield, Mark D.; Teare, Diane (2011). Designing Cisco Network Service Architectures (ARCH): Foundation Learning Guide. Foundation Learning Guides (3 ed.). Cisco Press. p. 464. ISBN 9781587142888. Retrieved 2013-06-13. Cisco AnyConnect is a Cisco implementation of the thick client. Because the SSL VPN network extension runs on top of the SSL protocol, it is simpler to manage and has greater robustness with different network topologies such as firewalls and Network Address Translation (NAT) than the higher security of IPsec.
  9. ^ a b Mavrogiannopoulos, Nikos (2013-11-17). "nmav's Blog: Inside an SSL VPN protocol". Nmav.gnutls.org. Retrieved 2018-08-13.
  10. ^ "Release Notes for the Cisco ASA Series, 9.10(x)". Cisco. December 12, 2018.
  11. ^ "ocserv issues #51".
  12. ^ Nikos Mavrogiannopoulos. "Recipe: VoIP network with ocserv".
  13. ^ "Open Source License Notices for the SPA525G" (PDF). Cisco.
  14. ^ David Woodhouse (September 23, 2008). "DTLS clue requested".
  15. ^ David Woodhouse. "How the VPN works § DTLS compatibility".
  16. ^ https://gitlab.com/openconnect/openconnect/-/issues?label_name%5B%5D=PPP
  17. ^ Daniel Lenski (September 17, 2020). "How VPNs Work- The Ins and Outs". DAMA Portland.
  18. ^ "Openconnect graphical client". GitHub. Retrieved 2014-10-28.
  19. ^ "NetworkManager-openconnect". gnome.org. Retrieved 2020-01-27.
  20. ^ "NetworkManagement". kde.org. Retrieved 2014-10-28.
  21. ^ cernekee. "Android UI for OpenConnect VPN client". GitHub. Retrieved 2014-10-28.
  22. ^ "VPN Overview". openwrt.org. Retrieved 2018-03-15.

External links[edit]

Some useful usage information.