Embodiments presented herein relate to establishing a secure connection, and particularly to methods, an access point, a network gateway, a client device, computer programs, and a computer program product for establishing a secure connection between a client device and a network gateway.
In communications networks, there may be a challenge to obtain good performance for a given communications protocol, its parameters and the physical environment in which the communications network is deployed.
For example, one parameter in providing good performance in a communications network is the ability to provide secure connections from a client device to the communications network.
In general terms, small and growing enterprises, in which several client devices are located, may need their own information technology infrastructure to be able to operate, for example to enable the client devices to communicate with each other, as well as for the client devices to communicate with other entities in, or operatively connected to, a communications network. However, resources and time needed for setting up and maintaining such an information technology infrastructure might be quite high. Also, for growing enterprises, where the number of client devices is increasing, their information technology infrastructure needs to be updated frequently to cope with the varying demand on it. To cope with this, one alternative studied is the use of so-called virtual customer premises equipment (vCPE). By means of vCPEs the information technology infrastructure may be performed by means of cloud computing, i.e. virtualized. The enterprise may then be provided with a virtual customer premises equipment which acts as an interface to the cloud computing information technology infrastructure. This enables flexibility and dynamics with respect to the required information technology infrastructure.
The client devices are thereby operatively connected to a network gateway of the cloud computing information technology infrastructure by the vCPE. Since the client devices may exchange sensitive information with the cloud computing information technology infrastructure the connection between the client device and the gateway network should be secure.
Hence, there is a need for enabling secure connection between a client device and a network gateway.
An object of embodiments herein is to provide a secure connection between a client device and a network gateway.
According to a first aspect there is presented a method for establishing a secure connection between a client device and a network gateway. The method is performed by an access point. The method comprises establishing a first secure connection between the access point and the network gateway. The method comprises establishing a second secure connection serving as a virtual private network tunnel between the client device and the network gateway.
Advantageously, this provides a secure connection between a client device and a network gateway. Thus, this enables end-to-end security between a client device and a cloud computing information technology infrastructure.
Advantageously, this may reduce unnecessary encryption/decryption operations, thereby improving throughput performance.
Advantageously, this may allow separate security associations between the access point and the network gateway, as well as end-to-end between the client device and the network gateway.
According to a second aspect there is presented an access point for establishing a secure connection between a client device and a network gateway. The access point comprises a processing unit. The processing unit is configured to establish a first secure connection between the access point and the network gateway. The processing unit is configured to establish a second secure connection serving as a virtual private network tunnel between the client device and the network gateway.
According to a third aspect there is presented a computer program for establishing a secure connection between a client device and a network gateway, the computer program comprising computer program code which, when run on a processing unit of an access point, causes the processing unit to perform a method according to the first aspect.
According to a fourth aspect there is presented a method for establishing a secure connection between a client device and a network gateway. The method is performed by the network gateway. The method comprises establishing a first secure connection between the access point and the network gateway. The method comprises establishing a second secure connection with the access point to serve as a virtual private network tunnel between the client device and the network gateway.
According to a fifth aspect there is presented a network gateway for establishing a secure connection between a client device and the network gateway. The network gateway comprises a processing unit. The processing unit is configured to establish a first secure connection between the access point and the network gateway. The processing unit is configured to establish a second secure connection with the access point to serve as a virtual private network tunnel between the client device and the network gateway.
According to a sixth aspect there is presented a computer program for establishing a secure connection between a client device and a network gateway, the computer program comprising computer program code which, when run on a processing unit of the network gateway, causes the processing unit to perform a method according to the fourth aspect.
According to a seventh aspect there is presented a method for establishing a secure connection between a client device and a network gateway. The method is performed by the client device. The method comprises establishing a second secure connection with the access point to serve as a virtual private network tunnel between the client device and the network gateway.
According to an eight aspect there is presented a client device for establishing a secure connection between the client device and a network gateway. The client device comprises a processing unit. The processing unit is configured to establish a second secure connection with the access point to serve as a virtual private network tunnel between the client device and the network gateway.
According to a ninth aspect there is presented a computer program for establishing a secure connection between a client device and a network gateway, the computer program comprising computer program code which, when run on a processing unit of the client device, causes the processing unit to perform a method according to the seventh aspect.
According to a tenth aspect there is presented a computer program product comprising a computer program according to at least one of the third aspect, the sixth aspect, and the ninth aspect and a computer readable means on which the computer program is stored.
It is to be noted that any feature of the first, second, third, fourth, fifth, sixth, seventh, eight, ninth and tenth aspects may be applied to any other aspect, wherever appropriate. Likewise, any advantage of the first aspect may equally apply to the second, third, fourth, fifth, sixth, seventh, eight, ninth, and/or tenth aspect, respectively, and vice versa. Other objectives, features and advantages of the enclosed embodiments will be apparent from the following detailed disclosure, from the attached dependent claims as well as from the drawings.
Generally, all terms used in the claims are to be interpreted according to their ordinary meaning in the technical field, unless explicitly defined otherwise herein. All references to “a/an/the element, apparatus, component, means, step, etc.” are to be interpreted openly as referring to at least one instance of the element, apparatus, component, means, step, etc., unless explicitly stated otherwise. The steps of any method disclosed herein do not have to be performed in the exact order disclosed, unless explicitly stated.
The inventive concept is now described, by way of example, with reference to the accompanying drawings, in which:
The inventive concept will now be described more fully hereinafter with reference to the accompanying drawings, in which certain embodiments of the inventive concept are shown. This inventive concept may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided by way of example so that this disclosure will be thorough and complete, and will fully convey the scope of the inventive concept to those skilled in the art. Like numbers refer to like elements throughout the description. Any step or feature illustrated by dashed lines should be regarded as optional.
The communications network comprises access points 20. In general terms, each access point 20 may be provided in a customer premises equipment (CPE) and thus define a virtual customer premises equipment (vCPE). The access point 20 may be configured for wireless and/or wireline communication. Each access point 20 may refer to a device such as a telephone, a router, a switch, a residential gateway (RG), a set-top box, a fixed mobile convergence product, a home networking adaptor, or an internet access gateway, that generally enable client devices 40 to access services as provided by a cloud computing information technology infrastructure 10 (hereinafter denoted cloud infrastructure 10 for short). The access points 20 may thus interface a local client network at different enterprise sites, as represented by the client devices 40, with the central cloud infrastructure 10.
The communications network not only provides the flexibility of the cloud infrastructure 10 to scale up or down based on the resource requirements, but also provides a uniform network environment across different sites where client devices 40 may be located. This also allows the client devices 40 to have access to the same network environment in remote locations.
The cloud infrastructure 10 may host entities and functions relating to firewalls, Dynamic Host Configuration Protocol (DHCP) servers, network address translators (NATs), etc. and be operatively connected to network management stations 14, and portals 15.
A central controller 11 in the central cloud infrastructure 10 is responsible for instantiating virtual machines, configuring and controlling network segments, as well as adding new network elements such as routers/bridges to the cloud infrastructure 10. The controller 11 may be a software-defined networking (SDN) controller. The controller 11 thereby has the full view of the cloud infrastructure 10 and based on administrator configured policies, it can enforce policies based on a per user, application, or device basis.
The controller 11 may be operatively connected to a number of functions 12a-h in the cloud infrastructure 10, such as dashboards 12a, SLA managers 12b, lifecycle management 12C, performance monitoring 12d, service chaining 12e, location optimizers 12f, connecting monitors 12g, and network configurators 12h.
The controller 11 is operatively connected to an authentication server 13. The authentication server 11 may provide a network service that applications use to authenticate credentials, such as account names and passwords, of their users. Thus, when a client device 40 submits a valid set of credentials, it may from the authentication server 13 receive a cryptographic ticket that the client device 40 may subsequently use to access various services of the cloud infrastructure 10. Particular details of the functionality of the authentication server 13 will be provided below.
The network gateway 30 would be the first point of contact in the cloud infrastructure 10 for the access point 20. The access point 20 may authenticate itself to the cloud infrastructure 10 and maintain a secure association with the network gateway 30. Client devices 40 which should access the cloud infrastructure 10 may be required to authenticate themselves before they may obtain access to the cloud infrastructure 10 and its services through the access point 20.
As noted above, the access points 20 may enable client devices 40 to connect to the central cloud infrastructure 10 either through a wireless connection or a wireline connection. However, existing wired networks typically do not perform any access authentication or perform a rudimentary access authentication based on the media access control (MAC) address of the client device 40. Wireless networks, on the other hand, typically rely on Wi-Fi Protected Access II pre-shared key mode (WPA2-PSK) for authenticating client devices 40 and creating security associations. WPA2-PSK relies on a common shared secret between the access point 20 and the connecting client devices 40. Some wireless based networks may also use WPA2-Enterprise with 802.1x (so called Extensible Authentication Protocol, EAP, over local area network, EAPOL) based authentication and secure connection establishment. An access point 20 that uses WPA2-Enterprise relies on an external trusted authentication server for authenticating client devices 40 and establishing security associations. While EAP access authentication is typically used for wireless networks, it can nevertheless be used over wired networks as well.
A brief description of WPA2-Enterprise access authentication is provided next. A connecting client device 40 discovers the access point 20 based on beacons/probes and the client device 40 and the access point 20 negotiate security capabilities and establish an 802.11 channel. The connecting client device 40 on discovering that the access point 20 requires WPA2 Enterprise authentication, sends and EAPOL-Start message. The access point 20 then requests the identity of the client device 40 with an EAP-Request/Identity message.
The client device 40 sends an EAP-Response message containing its identity. The access point 20 on receiving this identity decapsulates it from the EAP message and encapsulates it in a Radius/Diameter message that is then sent to the network gateway 30 which forwards the message to the authentication server 13 (Radius/Diameter server). Then, based on the EAP authentication method used, further request responses may be sent between the client device 40 and the authentication server 13 which are encapsulated and decapsulated by the access point 20 in-between. A successful authentication typically results in the derivation of keying material between the client device 40 and the authentication server 13. This key is referred to as the Master key (MK).
The authentication server 13 indicates the successful authentication to the access point 20 through the network gateway 30 and also sends a Pairwise master Key (PMK) derived from the MK. The client device 40 also derives the PMK from the MK and uses it to perform a 4-way handshake with the access point 20 for negotiating WPA2 security. This results in a time-limited session key called Pairwise Transient Key protecting the unicast traffic and a Group-wise transient key for multicast traffic.
The access point 20 may authenticate itself to the cloud infrastructure 10 and establish a secure association with the network gateway 30 using certificates, SIM based authentication, raw public-keys, (pre-)shared keys, leap-of-faith etc.
The embodiments disclosed herein particularly relate to enabling secure connection between a client device 40 and a network gateway 30. In order to obtain such secure connection there is provided methods, an access point 20, a network gateway 30, a client device 40, computer programs, and a computer program product for establishing a secure connection between the client device 40 and the network gateway 30 (and thus the authentication server 13).
such as an establish module 31a configured to perform below steps S202, S204. The network gateway 30 of
In the example of
Reference is now made to
The access point 20 is configured to take part in establishment of (at least) two secure connections; a first secure connection between the access point 20 and the network gateway 30, and a second secure connection between the client device 40 and the network gateway 30. Particularly, the access point 20 is configured to in a step S102 establish a first secure connection between the access point 20 and the network gateway 30. The access point 20 is configured to in a step S108 establish a second secure connection serving as a virtual private network (VPN) tunnel between the client device 40 and the network gateway 30.
Thereby, a secure connection is established between the client device 40 and the network gateway 30 with the help of the access point 20. In this respect, it to the client device 40 appears as if the second secure connection is set up to the access point 20, not the network gateway 30. Normally, if setting up a secure connection to a network gateway 30, the access point 20 would not be involved other than for routing/forwarding packets and the VPN setup would be done after access authentication. In contrast, as herein disclosed, the VPN setup is performed as part of the access authentication.
Reference is now made to
Embodiments relating to further details of the first secure connection will now be disclosed.
Establishing the first secure connection may be based on certificates, subscriber identity module (SIM) based authentication, policies set by a service provider of the access point 20, raw public-keys, (pre-)shared keys, leap-of-faith, etc.
The first secure connection may define a separate control channel between the access point 20 and the network gateway 30. The access point 20 may be configured to in an optional step S104 receive and send software-defined networking (SDN) control signalling for the access point 20 on the separate control channel. The network access point 20 may further be configured to in an optional step S106 selectively allow or deny traffic of the client device 40 based on the SDN control signalling.
Embodiments relating to further details of the second secure connection will now be disclosed.
There may be different ways of establishing the second secure connection. For example, the access point 20 may be configured to in an optional step S108a establish the second secure connection by receiving an access request from the client device 40. The access point 20 may then be configured to in an optional step S108b forward the access request to the network gateway 30. Additionally or alternatively the access point 20 may be configured to in an optional step S108c establish the second secure connection by facilitating establishment of an Extensible Authentication Protocol (EAP) access authentication between the client device 40 and the network gateway 30. The access point 20 may, for example, be configured to in an optional step S108d establish the EAP access authentication by receiving a shared pairwise master key (PMK) from the network gateway 30.
In general terms, the authentication server 13 and the client device 40 may both generate the PMK. The authentication server then gives the PMK to the network gateway 30. Now the network gateway 30 and the client device 40 have a shared secret, the PMK, which can be used for setting up, for example, WiFi security in a 4-way handshake. In a first case (actual VPN used with DG-PMK) the PMK is given from the authentication server 13 to the access point 20, passed through the network gateway 30. In second and third cases the PMK is only given to the network gateway 30. These three cases will be further disclosed below with reference to collective embodiments relating to the access point 20, the network gateway 30 and the client device 40.
The access point 20 may further be configured to in an optional step S108e provide the client device 40 with a network address to the network gateway 30. The access point 20 may further be configured to in an optional step S108f establish the second secure connection by facilitating exchange of a device-to-gateway pairwise master key (DG-PMK) between the client device 40 and the network gateway 30. In this respect, the DG-PMK may be generated by the authentication server 13 and the client device 40, and then communicated from the authentication server 13 to the network gateway 30. The connection between the client device 40 and the network gateway 30 may be secured/protected using the DG-PMK. The DG-PMK may be determined using a key derivation function (KDF) and a master key (MK).
Establishing the second secure connection may comprise receiving and forwarding messages between the client device 40 and the network gateway 30. The method according to claim 1, The access point 20 may further be configured to in an optional step S108g establish the second secure connection by facilitating a 4-way handshake between the client device 40 and the network gateway 30. The method according to claims 8 and 13, The access point 20 may be configured to in an optional step S108h facilitate the 4-way handshake by receiving and forwarding parameters of a pairwise transient key (PTK), or a group temporal key (GTK), from and to the client device 40 and the network gateway 30. The PTK or GTK may be based on the PMK.
The access point 20 may be configured to in an optional step S110, after having established the second secure connection, receive and forward encrypted packets between the client device 40 and the network gateway 20 over the second secure connection. Hence, the access point 20 may act as a relay between the client device 40 and the network gateway 30.
The access point 20 may block non-encrypted packets. That is, the access point 20 may be configured to in an optional step S112, after having established the second secure connection, block reception and forward of non-encrypted packets from and to the client device 40 and the network gateway 30 on the second secure connection.
Establishing the first secure connection may be performed prior to establishing the second secure connection. That is, step S102 may be performed before step S104. Establishment of the first secure connection may be performed upon power up of the access point 20.
Embodiments relating to details of a third secure connection will now be disclosed.
The third secure connection may be a separate secure connection between the access point 20 and the client device 40. Thus, the access point 20 may be configured to in an optional step S114 establish a third secure connection between the access point and the client device.
Establishing the third secure connection may be performed prior to establishing the second secure connection. That is, step S114 may be performed before step S104.
Reference is now made to
As noted above, a first secure connection is established between the access point 20 and the network gateway 30, and a second secure connection is established between the client device 40 and the network gateway 30. The network gateway 30 is therefore configured to in a step S202 establish a first secure connection between the access point 20 and the network gateway 30. The network gateway 30 is further configured to in a step S204 establish a second secure connection with the access point 20 to serve as a virtual private network tunnel between the client device 40 and the network gateway 30.
Reference is now made to
Embodiments relating to further details of the second secure connection will now be disclosed.
As noted above, the access point 20 may be configured to facilitate exchange of a device-to-gateway pairwise master key (DG-PMK) between the client device 40 and the network gateway 30. Hence, the network gateway 30 may be configured to in an optional step S204a establish the second secure connection by exchanging the DG-PMK with the client device 40 via the access point 30. As noted above, the DG-PMK may be determined using a key derivation function (KDF) and a master key (MK).
The network gateway 30 may perform access authentication functions of the access point 20 and send an EAP-Request/Identity message for the client device 40. Particularly, the network gateway 30 may be configured to in an optional step S204b establish the second secure connection by performing access authentication for the client device 40 on behalf of the access point 20 by sending an EAP-Request/Identity message to the client device via the access point 20.
There may be different ways to perform the access authentication for the client device 40. For example, the network gateway 30 may be configured to in an optional step S204c perform the access authentication by encapsulating and decapsulating EAP-Request/Response messages to Remote Authentication Dial In User Service (RADIUS) messages and/or Diameter Access-Request and Access-Challenge messages on behalf of the access point 20, and communicate the messages with an authentication server 13.
On successful authentication, the radius/Diameter server may send a Radius/Diameter Access-Accept message with the PMK to the network gateway 30. The network gateway 30 may thus be configured to in an optional step S204d perform the access authentication by receiving a RADIUS/Diameter Access-Accept message comprising a pairwise master key (PMK) from the authentication server 13 on behalf of the access point 20.
The controller 11 may then, by means of the network gateway 30, instruct the access point 20 to add the client device 40 to a white-list and forward all encrypted packets to the network gateway 30. Thus, the network gateway 30 may be configured to in an optional step S204e establish the second secure connection by sending instructions to the access point to add the client device 40 to a white-list and to forward all encrypted packets between the client device 40 and the network gateway 30.
Reference is now made to
Again, as noted above, a first secure connection is established between the access point 20 and the network gateway 30, and a second secure connection is established between the client device 40 and the network gateway 30. The client device 40 is configured to in a step S302 establish a second secure connection with the access point 20 to serve as a virtual private network tunnel between the client device 20 and the network gateway 30.
Reference is now made to
Embodiments relating to further details of the second secure connection will now be disclosed.
As noted above, a device-to-gateway pairwise master key (DG-PMK) may be exchanged between the client device 40 and the network gateway 30. Hence, the client device 40 may be configured to in an optional step S302a establish the second secure connection by exchanging a device-to-gateway pairwise master key (DG-PMK) with the network gateway 30 via the access point 20. In general terms, the DG-PMK may only be used for scenarios based on using an explicit VPN tunnel between the client device 40 and the network gateway 30. In other scenarios the network gateway 30 may acquire a regular PMK which is used as basis for WPA security, Wired Equivalent Privacy (WEP) security, etc. being examples of security employed between the client device 40 and the access point 20 (or network gateway 30). In such scenarios, at least when WPA is used, the access point 20 forwards the 4-way key exchange between the client device 40 and the network gateway 30 to establish the security, which may be terminated at the network gateway 30, not at the access point 20. When DG-PMK is used, the authentication server 13 generates both a PMK and a DG-PMK. The PMK may then be used between the access point 20 and the client device 40 for WPA/WEP (etc.) and the DG-PMK may then be used for the explicit VPN tunnel. The explicit VPN tunnel may require that the client device 40 learns the IP address of the network gateway 30 from a default network gateway field of the DHCP message and then explicitly configures a VPN tunnel to that IP address using the separately generated DG-PMK key. However, the client device 40 may just use the PMK for WPA/WEP (etc.) as for a regular access point 20, but the endpoint is actually at the network gateway 30. If the DG-PMK approach is not used, PMK may be used for WPA to the network gateway 30. In general terms, DG-PMK may be used for securing the connection between the client device 40 and the network gateway 30 and PMK may be used for securing the connection between the client device 40 and the access point 20.
The client device 40 may re-use an EAP identity when establishing the secure tunnel with the network gateway 30 to identify which DG-PMK the network gateway 30 should use. That is, the client device 40 may be configured to in an optional step S302b establish the second secure connection by performing access authentication with the access point 20 by receiving an EAP-Request/Identity message from the access point 20, wherein the message has been sent from the network gateway 30.
Three particular embodiments relating to the above general embodiments will now be disclosed in detail.
As disclosed above, when the access point 20 is switched on, it may establish a security association with the network gateway 30. This may require strong authentication and may be performed with SIM-based credentials, certificates, raw public-keys, (pre-)shared keys, leap-of-faith, etc. The exact mechanism used for this strong authentication and security association establishment may depend on the policies set by the access point 20 solution provider. However, the herein disclosed embodiments do not rely on the use of specific credentials or authentication mechanism for this.
As illustrated in
As illustrated in the signalling diagram of
Therefore, the client device 40, in addition to the PMK, has another shared secret DG-PMK that is shared with the network gateway 30. This shared secret may be used for establishing an end-to-end secure tunnel between the client device 40 and the network gateway 30 that may be protected inside previously used hop-by-hop tunnels. For example, the client device 40 may receive the address of the network gateway 30 as part of initial network configuration information from the access point 20. The access point 20 may include the address of the network gateway 30 as the default gateway address. The client device 40 may then use the DG-PMK and the gateway address received to establish the secure tunnel to the central cloud infrastructure 10). The client device 40 may re-use the EAP identity when establishing the secure tunnel with the network gateway 30 to identify which DG-PMK the network gateway 30 should use. The network gateway 30 receives the identity/DG-PMK mapping from the Authentication server. Using this method, the client device 40 or the network gateway 30 does not need to perform additional authentication or security negotiations using certificates or passwords for achieving end-to-end security. The EAP authentication and key negotiation is thus extended to provide network access authentication and end-to-end security association establishment in a single round.
However, as is evident, this end-to-end security makes the PTK/GTK based secure tunnel between the client device 40 and the access point 20 at least appear to be redundant. This method may also require modifications to the wpa_supplicant daemon (EAP client) residing in the client device 40 and the hostapd daemon (EAP server) residing in the Authentication server.
A modification of the embodiment illustrated in
According to such an embodiment the authentication request would be initiated by the client device 40, as shown in the signalling diagram of
In this way, all traffic from the client device 40 to the cloud infrastructure 10 is encrypted, and the access point 20 only has to perform basic access control and packet forwarding. According to this embodiment the client device 40 does not need to have any additional VPN, or other security software installed and configured, in order to have an end-to-end security to the network gateway 30.
From
When the access point 20 is configured using SDN to allow the traffic of the authenticated client device 40, the client device 40 may be put into a list of accepted clients. The access point 20 may not be enabled to verify that the client device 40 is sending authorized packets (i.e. that the packets can be decrypted in the cloud infrastructure 10). Instead, it is the secure connection endpoint in the cloud infrastructure 10 that needs to take care of this. With this setup the access point 20 may further be configured to block all non-encrypted packets to protect against MAC spoofing. An attacker may thereby not send plaintext messages using the MAC address of the client device 40. Likewise, an attacker can not send valid encrypted messages with a spoofed MAC since the attacker does not know the key to use for encrypting the message and thus the secure connection endpoint in the cloud infrastructure 10 will not be able to decrypt the message either. The network gateway 30 may inform the access point 20 about such malicious behavior such that appropriate actions may be taken. This embodiment does not require any changes to be made to the client device 40.
In summary, at least some of the herein disclosed embodiments enables the functionality of the access point 20 to be split such that, for example, WPA2/WLAN security is established between the client device 40 and the network gateway 30 instead of between the client device 40 and the access point 20. This provides end-to-end security for the client device 40, in some embodiments without any modifications or configuration of the client device 40.
The inventive concept has mainly been described above with reference to a few embodiments. However, as is readily appreciated by a person skilled in the art, other embodiments than the ones disclosed above are equally possible within the scope of the inventive concept, as defined by the appended patent claims.
Number | Date | Country | |
---|---|---|---|
Parent | 15529539 | May 2017 | US |
Child | 17940802 | US |