The various embodiments will be described by way of exemplary configurations, but not limitations, illustrated in the accompanying drawings in which like references denote similar elements, and in which:
Various embodiments, described below, have been developed in response to the current state of the art and, in particular, in response to the previously identified problems and needs of secure authentication and authorization that have not been fully or completely solved by currently available authentication systems and protocols for distributed network devices. Embodiments provide a method to increase authentication security and thereby reduce time, power, and computational cycles required for a client device to obtain access to a network. In at least one embodiment, a client device attests to platform information by signing the data with a key known to the client and the policy server, in an OS independent manner, without fundamentally impacting the underlying security frameworks being used by the network. The policy server (e.g., a PDP) can validate the posture using a reciprocal key to ensure that the posture data has not been modified en route. Signed platform posture information (generated in an OS independent manner) may be distributed independent of the OS to a posture validation server to bypass the performance of a full and thorough re-evaluation of the host platform device, so long as the host platform device continues to maintain a valid key and to satisfy network security criteria. Moreover, signed platform posture information may also be divided into at least one data fragment and individually validated. Upon determining that each individual data fragment may be authenticated, policy information associated with the received platform posture information may be collated from at least one server backend plug-in and transmitted to the qualified host platform device.
In the following detailed description, reference is made to the accompanying drawings which form a part hereof wherein like numerals designate like parts throughout, and in which are shown, by way of illustration, specific embodiments. It is to be understood that other embodiments may also be utilized and structural or logical changes may be made without departing from the scope of the invention. In other instances, well-known circuits, structures and techniques have not been shown in detail in order not to obscure the understanding of this description. Therefore, the following detailed description is not to be taken in a limiting sense, and the scope of the various embodiments is defined by the appended claims and their equivalents.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification do not necessarily all refer to the same embodiment, but they may. The phrase “A/B” means “A or B”. The phrase “A and/or B” means “(A), (B), or (A and B)”. The phrase “at least one of A, B, and C” means “(A), (B), (C), (A and B), (A and C), (B and C) or (A, B and C)”. The phrase “(A) B” means “(A B) or (B)”, that is “A” is optional.
Reference in the specification to a “digital device” means that a particular feature, structure, or characteristic, namely device operable programmability or the ability for the device to be configured to perform designated functions, is included in at least one embodiment of the digital device as used herein. Typically, digital devices may include general and/or special purpose computing devices, such as a laptop computer, a personal digital assistant (PDA), mobile phone, and/or console suitably configured for practicing the present invention in accordance with at least one embodiment. The terms “client device” and “host device” are often synonymously used herein and are interchangeable with digital device as previously defined. Reference in the specification to “remote device” means a network device electronically coupled to the digital device or host platform via a network interface and suitably configured for practicing the present invention in accordance with at least one embodiment. Exemplary network devices may include general and/or special purpose computing devices, such as a network access policy decision point (PDP), a Policy Enforcement Point (PEP), a gateway, a router, a bridge, a switch, a hub, a repeater, and/or a server.
Referring to
The illustrated host platform device 110 includes a network interface 130, a first processor 140, a second processor 150, an operating system 145, one or more software components 147, and one or more platform management components 170, operationally coupled to each other as shown. The one or more software components 147, such as independent software vendor (ISV) agents, are adapted to be executed by the first processor 140 under the direction of the operating system 145.
The platform management components 170 are adapted to be executed by the second processor 150, independent of the operating system 145. The platform management components 170 are also configured to determine platform posture information independent of the operating system 145 and to generate signed platform posture information 180 based on a posture signature key 177 to obtain network access control policy information for the host platform device 110.
The network interface 130, coupled with the first processor 140 and/or the second processor 150, is configured to communicate with the at least one remote device 120 across communication network 180. The network interface 130 is configured to transmit the signed platform posture information 160 (generated independent of the OS) to the at least one remote device 120 and to receive, via the at least one network interface 130, policy information 127 sent in response by the remote device 120. The communication network 180 may include at least one gateway, router, bridge, switch, hub, repeater, and/or server. Additional components may be included in various embodiments of the host platform device 110 which are not illustrated in
In various embodiments, the platform management components 170 determine and sign platform posture information 160 of the host platform device 110 via firmware agents 175, independent of operating system 145. In one embodiment, firmware agents 175 exhibit at least two characteristics: 1) no code executing within the host operating system 145 can modify or tamper with firmware agent code, prevent firmware agent code from running, or circumvent operation of the firmware agent 175; and 2) firmware agents 175 have exclusive access to certain host resources, for example filters 135 associated with the network interface 130 and posture signature keys 177 and unrestricted access to other resources, such as non-volatile storage 155 and associated controllers. In this manner, embodiments may provide a tamper resistant execution environment on host platform device 110 which may allow the trust anchor 112 of host platform device 110 to act as a PEP acting on behalf of the network administrator to restrict or enable network access of the host platform device 110, based on detected operational conditions. In one embodiment, at least some platform operational conditions may be reported to the remote device 120 in the form of signed platform posture information 160.
The signed platform posture information 160 is provided to the remote device 120 via the network interface 130 across communications network 180. In one embodiment, the signed platform posture information 160 includes host posture information and/or firmware posture information. In one embodiment, the signed platform posture information 160 includes at least one posture signature key 177. In one embodiment, one or more platform management components 170 are adapted to determine platform posture information, independent of the operating system. The one or more platform management components 170 are adapted to generate signed platform posture information 160 based on a selected posture signature key 177. The signed platform posture information 160 may be transmitted to the remote device 120 to obtain policy information 127 for the host device. The transmission may be made through the input/output interface of the trust anchor 112 and the networking interface 130 of the at least one host platform 110. The posture signature key 177 of the host system may be stored on either the non-volatile storage 155 or another storage of the at least one host platform 110.
In one embodiment, the posture signature key 177 may either identify whether the host platform device 110 continues to satisfy network security criteria or whether an intervening event may require the host platform device 110 to be re-authenticated. For example, in one embodiment, a key associated with filters 135 may be designated for expiration after a period of time so that they can be securely refreshed by a PDP on a subsequent connection attempt during re-authentication.
In one embodiment, the at least one posture signature key 177 is associated with at least one reciprocal signature key 179 employed by the PDP to validate the received signed platform posture information 160. In one embodiment, the posture signature key 177 is a private key and the reciprocal signature key 179 is a public key. In one embodiment, the host platform device 110 transmits multiple posture signature keys 177 and the remote device 120 validates each of the posture signature keys 177 using a reciprocal signature key 179 associated with that posture signature key 177.
In one embodiment, the host platform device 110 may transmit encrypted posture AVP requests/responses or TLVs to the remote device 120 over an authenticated channel. In similar fashion, the remote device 120 may transmit encrypted AVP requests/responses or TLVs to the host platform device 110. In one embodiment, the signed platform posture information 160 may provide the encryption mechanism for the AVP requests/responses or TLVs.
In one embodiment, the trust anchor 112 may modify the signed platform posture information 160 and thereby authenticate the host platform based on previously received policy information including verified keys and/or access control lists (ACL). The ACL includes one or more constraints related to time of access, network traffic filters, firmware version, and/or firmware operational status.
In various embodiments, the signed platform posture information 160 is transmitted using multiple data fragments to the remote device 120. Each data fragment includes posture information associated with a platform component of the host platform. The signed platform posture information 160 contains information about the posture of various platform components including, but not limited to, the management engine (ME), host Operating System (O/S) 145, software services, hardware components, and any other entity deemed pertinent for evaluation based on administrative policy 127 and capabilities available within a given platform architecture.
The illustrated at least one remote device 120 may include a network access server (NAS) 121, network access policy decision point (PDP) 123, and a trust server 125. The trust server 125 may compare received posture attribute-value pair (AVPs) with administrative policies 127, which may include stored type-length values (TLVs) and/or AVPs 129, to determine whether to allow host platform device 110 to connect to additional network resources.
In one embodiment, the received signed platform posture information 160 is verified with at least one reciprocal signature key 179. In one embodiment, the trust server 125 disperses the multiple data fragments in the signed platform posture information 160 to specific server backend plug-in devices, such as the posture validation server as illustrated in
In one embodiment, the host platform device 110 may receive signed network access control policy information, such as signed AVPs containing instructions for remediation or access control lists (ACLs) to set filters 135. Accordingly, additional remote network devices and/or components may be included in various embodiments of the network which are not illustrated in
Referring to
In one embodiment, the access control server 210 includes at least one PDP. Likewise, in one embodiment, the posture validation server 220 includes at least one server backend plug-in. In one embodiment, the access control server 210 and posture validation server 220 are both separately in communication with a host platform. In one alternate embodiment, the access control server 210 and posture validation server 220 are part of the same network device.
In one embodiment, the posture validation server 220 optionally initiates a first transmission 230 by sending an application posture request to the access control server 210. In a second transmission 240, the access control server 210 transmits application posture information to the posture validation server 220. As previously noted, the second transmission 240 may be triggered by the optional application posture request sent in the first transmission 230. In one embodiment, the second transmission 240 may also be triggered by the expiration of a timer to update information and/or receipt of changed information regarding existing policy and/or posture information on the platform being monitored.
In one embodiment, the posture validation server 220 responds with a third transmission 250 of the two-phase commit exchange by sending an application policy decision. In one embodiment, the third transmission 250 includes an application posture token, which may be associated with the application policy information, that governs access to the access control server 210.
Upon receiving the application posture token, in one embodiment, the access control server 210 initiates a fourth transmission 260 of the exchange to the posture validation server 220 containing a system posture token, which includes policy information. The posture validation server 220 initiates a fifth transmission 270 to the access control server 210 to send signature information, including a signed system policy token and/or a signed application posture token. Upon receipt of the signature information the access control server 210 may send the policy information back to a Policy Enforcement Point (PEP) and/or client.
In another embodiment, the access control server 210 may provide the functionality to sign the overall system policy and verify the posture signature. Signature verification functions may include a wide range of algorithms including at least one of RSA (Rivest Shamir and Adleman), DSA (Digital Signature Algorithm), ECC (Error Correcting Code), DH (Diffie-Hellman), SHA (Secure Hash Algorithm), and AES (Advanced Encryption Standard) for cryptographic signature generation.
Turning now to
A storage medium includes any mechanism that provides (i.e., stores and/or transmits) information in a form readable by a machine (e.g., a computer). For example, a storage medium includes read only memory (ROM), random access memory (RAM), magnetic disk storage media, optical storage media, flash memory devices, electrical, optical, acoustical or other form of propagated signals (e.g., carrier waves, infrared signals, digital signals), and the like.
Describing the methods by reference to a flow diagram enables one skilled in the art to develop such programs, including instructions to carry out the methods on suitably configured host platforms and/or remote devices. In various embodiments, at least one of the processors of a suitably configured host platform and/or remote device executes the instructions from the storage medium. In various embodiments, the computer-executable instructions may be written in a computer programming language or may be embodied in firmware logic, reconfigurable logic, a hardware description language, a state machine, an application-specific integrated circuit, or combinations thereof. If written in a programming language conforming to a recognized standard, such instructions may be executed on a variety of hardware platforms and may interface with a variety of operating systems.
The present various embodiments are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the embodiments as described herein. Furthermore, it is common in the art to speak of software in one form or another (e.g., program, procedure, process, application, etc.) as taking an action or causing a result. Such expressions are merely a shorthand way of saying that execution of the software by a network device causes the processor of the computer to perform an action or a produce a result.
Referring to
In response to the received request, the host platform device 300 gathers platform posture information, independent of the platform's operating system in block 320. In one embodiment, one or more platform management components are adapted to determine platform posture information, independent of the operating system.
In block 330, the host platform device 300 generates a signature over the posture information. In one embodiment, the one or more platform management components are adapted to generate signed platform posture information based on a posture signature key, the posture signature key of the host system to be stored on either non-volatile storage of the trust anchor or storage of the host platform device.
In response to the initial request, the host platform device 300 returns posture data and signature information in block 340. In one embodiment, the signed posture information 330 may be used to obtain policy information for the host device through the networking interface of the host platform device 300. In one embodiment, the posture data and signature information is ultimately routed to a policy server which is equipped to make authorization decisions on network access, based on an administrative policy, via a control channel connection.
As previously indicated, the signed platform posture information may be transmitted using multiple data fragments. In one embodiment, each data fragment includes posture information associated with a platform component of the host platform. In one embodiment, the signed platform posture information includes a posture signature and at least one of host posture information and/or firmware posture information of the host device. In one embodiment, the host posture information includes at least one identification selected from the group consisting of platform identification, platform revision identification, Basic Input/Output System (BIOS) revision identification, Extensible Firmware Interface (EFI) revision identification, host operating system revision identification, and Trusted Platform Module capability identification. In one embodiment, the firmware posture information includes one or more parameters selected from the group consisting of an operational mode, a transport layer security (TLS) state, a Crypto enable fuse state, a provisioning state, a network interface state, an IDER state, a Serial over LAN (SoL) state, a firmware (FW) update state, a posture version state, a module version state, a link state, a posture version identification, a vendor identifier, a build date identifier, a posture image size, a number of modules, a module identifier, a module version identification, a module size, and a module flag.
Once the posture data and signature information has been collected, the host platform device 300 packages the posture data and signature information for transmission to a remote device in block 350. As part of the signature information, the host platform device 300 may be configured to provide public keys to the remote device for subsequent policy signature generation and verification. Once the signed posture information is successfully packaged and transmitted, the relevant portion of the operations on the host device 300 may end in block 390.
Referring to
In the case of a valid signature, the remote device 400 may make a corresponding policy decision with respect to the access request from the client in block 440. In one embodiment, a valid signature represents a device acceptable to the network and the policy decision determines the type of access that will be granted. Once the policy information has been determined and collected, the remote device 400 signs the applicable policy information and sends the signed policy information back. In one embodiment, the remote device 400 is further adapted to transmit in block 450 the signed policy information to the host client device and/or a policy enforcement point (PEP). In one embodiment, network policy and platform policy are consolidated into the policy information at the remote device 400 using a multi-phase commit process. Once the signed policy information is successfully transmitted, the relevant portion of the operations on the remote device 400 may end in block 470.
Alternatively, if the signature is not found to be valid in query block 430, the remote device 400 may discard the received platform posture information and initiate quarantine procedures to move the client transmitting the invalid posture information to a remediation network in block 460. Once the invalid access request from the client is sent to the remediation network, the relevant portion of the operations on the remote device 400 may end in block 470.
Referring to
Upon determining that the signature is valid, the PEP 500 may apply the policy information to network access filters on the requesting host platform device, such as callback (CB) filters, in block 530.
Alternatively, in one embodiment, if query block 520 determines that the signature is invalid, the PEP 500 sets a CB filter in block 540 to a limited rate. In one embodiment, the filter may enable certain components to pass to the trust anchor, according to a rate limit, while restricting other components. In one embodiment, the filter is set to pass Extensible Authentication Protocol (EAP) and/or Dynamic Host Configuration Protocol (DHCP) communication on a limited basis. In one embodiment, the transceiving rate is restricted to about one packet per minute. This enables the device to eventually initiate a new access request without burdening the network with excessive access attempts, which may even be the purpose of an infected device.
Referring to
At least three different types of access request are illustrated in
In a second type, the at least one access control server 620 receives an access request 650 to the network domain 640 from a requesting host device 610b which includes either posture information or signature keys. The access request 650 may include signed information 660b associated with the requested access grant of the requesting host device 610. In one embodiment, the signed information 660b may be collected by one or more platform management components executing independent of an operating system on the requesting host device 610. The at least one access control server 620 determines whether to grant the requested network access based at least in part on the received signed information 660b associated with the access request 650. If network access is to be granted, the at least one access control server 620 retrieves what policy information 680, if any, is to govern the network access of the requesting host device 610 based at least in part on the received signed information 660b associated with the access request 650. In one illustrated embodiment, the policy information 680 may be collected and signed by multiple posture validation servers 630a-b. As previously illustrated in
In a third type, the at least one access control server 620 receives an access request 650 to the network domain 640 from a requesting host device 610c which includes either invalid posture information or invalid signature keys. In this case, the at least one access control server 620 may discard the received posture information and quarantine the requesting host device 610c to a remediation network. This allows the requesting host device 610c to be authenticated, but alerts the network to potential problems with the device. Alternatively, the invalid signature keys may merely represent the expiration of previously issued authentication and the at least one access control server 620 may merely refresh or validate the requesting host device 610c.
In one embodiment, the at least one access control server 620 includes a network access server, a network policy decision point (PDP), and/or a trust server as previously described in
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art and others, that a wide variety of alternate and/or equivalent implementations may be substituted for the specific embodiments shown and described without departing from the scope of the present invention. This application is intended to cover any adaptations or variations of the embodiments discussed herein. Therefore, it is manifested and intended that the various embodiments be limited only by the claims and the equivalents thereof.