 
                 Patent Application
 Patent Application
                     20150222436
 20150222436
                    This document relates to secure electronic communication and controlling physical access to a facility.
Access to facilities can be controlled by a physical barrier such as a gate or a bar whose operation is controlled by a control computer. Such access-controlled facilities include various premises and structures, including public facilities, private facilities, parking structures and others.
The present document discloses techniques for securing the remote operation of a physical barrier for restricting entry or exit of a premise or facility. With the ubiquitous availability of communication networks such as the Internet, the physical barrier can be operated by communicating with one or more control computers or processors.
In one aspect a technique for securing message communication for controlling access to a facility includes generating a command, wherein the command specifies an action to be performed by an access mechanism to the facility, producing a complete command by adding a message number and a nonce to the command, generating an encrypted complete command by encrypting the complete command using a first private key, computing a hash of the encrypted complete command, calculating a digital signature by encrypting the hash using a second private key, and transmitting the encrypted complete command and the digital signature using a transmission protocol.
In another aspect, an apparatus for controlling access to a facility includes a network module that receives an encrypted complete command and a digital signature, a signature verification module that calculates a digital signature by decrypting the encrypted complete command using a first public key, a hash matching module that matches a hash of the encrypted complete command, a decryption module that generates a decrypted complete command by decrypting the complete command using a second public key, a message filter module that produces a complete command by removing a message number and a nonce to the command, and a command execution module that executes the command, wherein the command specifies an action to be performed by an access mechanism to the facility.
In yet another aspect, a system for securing access to a facility includes an access device that operates a physical barrier that controls access to the facility and a controller that is located remotely from the access device and controls operation of the access device by transmitting operation commands to the access device. The controller transmits an operation command by encrypting a command code by a first private key, calculating a hash value of the encrypted command code, signing the hash value by a second private key and including the encrypted command code and the signed hash value in the transmission. The access device receives the transmission, extracts the operation command, and upon successful extraction of the operation command, operates the physical barrier according to the operation command.
These, and other, aspects are described below in the drawings, the description and the claims.
    
    
    
    
    
    
    
    
    
    
Like reference symbols in the various drawings indicate like elements.
Access to a facility or premise can be controlled by a physical barrier. Examples of such a facility or premise include public places such as buildings, gated areas or locations and parking lots. The physical barrier may be operated by an electromechanical mechanism that is controlled to open or close a physical barrier. Examples of such mechanisms include a sliding gate, a swiveling gate, a bar that can be raised and brought down, spikes in the ground, latches or locks on doors, etc.
Various controlled access systems like parking gates have functioned in a standalone mode or within an isolated network. In some implementations, for example, the controller that controls the physical barrier is often co-located with the physical barrier. A hacker can hack such a system by gaining physical access to the control computer at the access controlled facility.
  
  
One of the operational challenges to securing communication between the remote controller 204 and the bar 102 is the cost of implementing security systems. For example, some public access systems generate a low amount of revenue on a per-transaction basis (e.g., 2 to 10 dollars per vehicle). Using encryption technology such as the Public Key Infrastructure (PKI), e.g., as is done in securing credit card transactions, may be a significant cost burden to a public access system operator. The use of PKI infrastructure often involves setting up business relationships with an encryption key issuing authority and with a key verification authority or a clearing house that authenticates online transactions. Such services often charge on a per-use basis. In general, the use of PKI may be expensive and could take away a significant amount of revenue generated by an operator of a public facility. Public access system operators would therefore prefer to deploy a less expensive yet secure solution.
  
As illustrated in 
  
At 402, the remote controller 204 creates a command in a format or protocol that is understood by the access device 102 at the access restricted premise or location.
At 404, the remote controller 204 adds a message number and a nonce (e.g., an arbitrary number used only once in a cryptographic communication) to the command. The message number may be used to cross-refer to any responses from the access device 102. The nonce may be included to strengthen the encryption against brute force attacks, as further explained in this document.
Typically, there are three elements to strengthening encryption: the cleartext to be encrypted, the encryption key and the encryption algorithm. A sophisticated hacker who gets possession of two out of the three elements may be able to calculate the third element. In public access systems, only a finite number of different messages may be exchanged between the control system 204 and the access device 102. For example, the messages may include directives such as “authenticate_request” to “authenticate_response” and may specify actions such as “gate open” and “gate close.” In other words, a sophisticated hacker may be able to capture a number of message transactions and make a reasonable estimate of the cleartext carried in the messages
In some embodiments, to avoid the calculation of the encryption key by a hacker, the cleartext that is transmitted is made different each time by addition of a message number and the nonce to avoid duplicate cleartext making brute force attacks harder. In one advantageous aspect, the user of a message number and the nonce can deter replay attacks.
At 406, the controller 204 encrypts the resulting cleartext plus message number and nonce. In some implementations, the encryption may be based on the use of a public key (for decryption) and a private key (for encryption) associated with the control system 204. The key used may be called private key 2 (PrK2). The key PrK2 may be known only to the controller 204 or the official control server 204 (and not the access device 102) and is not shared with an outside entity. In some embodiments, PrK2 may be used only for encryption of commands and not used for digital signature (described later) in order to avoid brute force discovery of PrK2.
At 408, the controller or control server 204 computes a hash of the encrypted message. The hashing algorithm used is known a priori both to the control server 204 and the access device 102.
At 410, the controller or control server 204 encrypts the hash calculated in 408 using the private key of a public-private key pair for the control server known as private key 1 (PrK1). The PrK1 is known only to the official control server 204 and is not shared. The PrK1 is used only for encryption of the hash and never used in the encryption of the commands in order to avoid brute force discovery of PrK1. The result of operation 410 called a digital signature of the transmission.
At 412, the controller or control server 204 associates the digital signature with the encrypted command as a message digest, e.g., by appending the digital signature to the encrypted command. The resulting data bits may be transmitted via a suitable protocol such as chat over the cloud to the device. For example, in some embodiments, the data bits may be transmitted as IP packets. In some embodiments, the data bits may be converted into a text message and transmitted as a short message service (SMS) text message.
  
At 502, the access device 102 separates the message digest containing the digital signature from the encrypted command.
At 504, the access device 102 decrypts the digital signature using the public key of a public-private key pair for the control server known as public key 1 (PuK1). The PuK1 may be known all of the access devices 102. The result of the calculation produces the original hash as computed by the control server.
At 506, the access device 102 calculates a hash of the encrypted command. The operations 504 and 506 may be done in any order or simultaneously because they do not depend on each other's results.
At 508, the access device 102 compares the original hash and the computed hash. If they match then method 500 performs the operation 512. If they do not match, then the access device 102 performs the operation 510.
At 510, the access device 102 may send an error message to the control server 204. Further, the access device 102 may hold the current state of the access device 102 (e.g., hold the access device in the open or the closed position).
At 512, the access device 102 may decrypt the command using the public key of a public-private key pair for the control server known as public key 2 (PuK2). The PuK2 may be known to all of the access devices. The result of the decryption operation 512 may include a cleartext version of the command, message number and nonce that were sent by the control system 204.
At 514, the access device 102 may generate and transmit an acknowledgement response back to the control server 204. The response may include the message number and the nonce for reference and variability of the response message, respectively. In some embodiments, the message may be encrypted by PuK2 for additional security. In some embodiments, upon receiving the response message, the control system 204 can use PrK1 to decrypt the acknowledgment response and alert an operator of any commands that do not have a proper response as this may indicate an outage or a cyber-attack. In some embodiments, the message number is stored by the access device 204 so that it is able to track what the next message number should be and avoid replay attacks. The nonce may be discarded.
At 516, the access device 102 may execute the command received in the message. The command received in the message may cause the access device 102 to activate (or deactivate) and electromechanical mechanism to unlock or move a physical barrier. The command may cause the access device 102 to perform diagnostic check-up of the system, and so on.
  
  
  
Using the message security methods, e.g., as described with respect to 
  
In some embodiments, an apparatus for controlling access to a facility includes a module (e.g., a network interface) for receiving a request message and transmit a response message over a communication network, a module (e.g., a decision module) for deciding, based on the request message, an operation to be performed on a physical barrier, and a module (e.g., an encryption module) for encrypting an operation command indicative of the operation to be performed on the physical barrier into the response message. The apparatus may encrypt a first portion of the response message using a first encryption key and a second portion of the response message using a second encryption key, e.g., as previously disclosed with respect to method 400.
  
In some embodiments, a method of controlling access to a facility includes receiving an encrypted complete command and a digital signature, calculating a digital signature by decrypting the encrypted complete command using a first public key, matching a hash of the encrypted complete command, generating a decrypted complete command by decrypting the complete command using a second public key, producing a complete command by removing a message number and a nonce to the command, and executing the command, wherein the command specifies an action to be performed by an access mechanism to the facility. In some embodiments the method further includes generating an acknowledgement message and including a response code in the acknowledgement message.
In some embodiments, the transmission protocol includes a simple messaging system (SMS) protocol. The receiving operation includes receiving the text message using the SMS protocol and converting the text message into the encrypted complete command and the digital signature. In some embodiments, when the matching of the hash of the encrypted complete command fails (e.g., results do not match with expected hash results), the received command is discarded and no change is made to the access mechanism, e.g., access mechanism remains in its position.
In some embodiments, a system for securing access to a facility includes an access device that operates a physical barrier that controls access to the facility and a controller that is located remotely from the access device and controls operation of the access device by transmitting operation commands to the access device. The controller transmits an operation command by encrypting a command code by a first private key, calculating a hash value of the encrypted command code, signing the hash value by a second private key; and including the encrypted command code and the signed hash value in the transmission. The access device receives the transmission, extracts the operation command, and upon successful extraction of the operation command, operates the physical barrier according to the operation command.
It will be appreciated that techniques for securing communication messages that control the operation of a physical barrier controlling access to a facility are disclosed. In some embodiments, the message security is accomplished without using public key infrastructure such as a certification authority. In one advantageous aspect, two different private keys can be used to encrypt transmitted messages—a first private key could be used for privacy reason—i.e., deterring unauthorized listeners from receiving and deciphering the message, and a second private key for calculating a hash of the encrypted message, thereby providing information to a receiver for ascertaining the validity of a received message.
The disclosed and other embodiments, the functional operations and modules described in this document can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this document and their structural equivalents, or in combinations of one or more of them. The disclosed and other embodiments can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer readable medium for execution by, or to control the operation of, data processing apparatus. The computer readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more them. The term “data processing apparatus” encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them. A propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a standalone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this document can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. However, a computer need not have such devices. Computer readable media suitable for storing computer program instructions and data include all forms of non volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto optical disks; and CD ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
While this document contains many specifics, these should not be construed as limitations on the scope of an invention that is claimed or of what may be claimed, but rather as descriptions of features specific to particular embodiments. Certain features that are described in this document in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable sub-combination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a sub-combination or a variation of a sub-combination. Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results.
Only a few examples and implementations are disclosed. Variations, modifications, and enhancements to the described examples and implementations and other implementations can be made based on what is disclosed.