FIELD OF THE INVENTION
The present invention relates generally to wireless communication and particularly to remote access.
BACKGROUND OF THE INVENTION
Network Administration services have become indispensable as businesses rely more heavily on Local Area Networks connected to the Internet to interact with their customers and their employees. Personnel capable of delivering those services are therefore in high demand and have accordingly become very expensive to maintain on staff. Mobile personnel able to provide high quality Network Administration services on a part-time basis, but on short notice to more than one business are therefore a desirable resource when they are able to provide an essential service for an acceptable price. Further, keeping mission critical technical infrastructure functioning correctly in times of a threat—one example is where a threat to a building forces the evacuation—all the critical systems and infrastructure are left inside the building while the IT staff are outside—unable to take the actions necessary to protect the network by performing administration functions including locking down core systems and users.
Without dedicating costly office space either on or off-site, or any other form of physical infrastructure that unnecessarily restricts the location of operation of a service or the mobility of the personnel supply those services, wireless technologies are a desirable means through which to deliver Network Administration services. Unfortunately, conventional methods of wireless communication are insufficient (in both capacity and security) for use administering networks such as LANs.
Known conventional technologies for administering networks wirelessly include those accessed through a web browser, using a standard micro-browser client/application running on any of a variety of PDAs, pagers, data capable cell phones or other Wireless Input Devices (“WIDS”) to access a web-server connected to the LAN or other network of Managed Entities whether in hardware or in software (including: servers, routers, desktops, modems, printers, switches, mainframes, serial or parallel devices, pagers, data capable phones, applications, services, or processes). These traditional approaches take advantage of existing infrastructure to provide an inexpensive and flexible (i.e. client WIDs need not be prepared or have client software loaded) way to access Managed Entities, but disadvantageously increase the risk of unauthorized access to the LAN through the web-server component of the service, a risk that is not acceptable to many businesses.
Wireless Transport Layer Security (WTLS) is based on Transport Layer Security (TLS) (similar to Secure Sockets Layer, SSL), WTLS was developed to address the problems of mobile network devices, including: narrow bandwidth, high latency environment, limited processing power and memory capacity. TLS was modified to address the needs of wireless users because radio networks do not provide end-to-end security. TLS is a protocol that is the successor to SSL. TLS has two layers: the TLS Record Protocol and the TLS Handshake Protocol. The Handshake Protocol allows the server and client to authenticate each other and to negotiate an encryption algorithm and cryptographic keys before data is exchanged. The Record Protocol provides session security using a particular method of encryption such as the Data Encryption Standard (DES), but can be used without encryption. TLS and SSL are not generally interoperable, but TLS can export for SSL.
Wireless Application Protocol (“WAP”) uses a specially developed protocol stack to implement the part of the wireless transmission from a WAP client device to a WAP Gateway. The WAP architecture replaces the current web server technology for the portion of data communication between a wireless device and the web server. A WAP Gateway implements the Internet protocol stack on behalf of the WAP client device. Since TCP/IP is not used for communication between the WAP client and the WAP Gateway, SSL or TLS could not be used to implement the security. WTLS can sustain the low bandwidth, high latency transport layer and is derived from TLS by removing the overhead where possible without compromising security that makes the protocol suitable for the wireless environment. Like TLS, WTLS operates on top of the wireless transport layer also known as WDP, and below the session layer known as WSP. However, WTLS runs on top of an unreliable datagram service, and not a reliable transport protocol like TCP/IP, creating reliability concerns respecting message exchanges across several WTLS operations. WTLS also uses digital certificates to provide for server or client side authentication, but due to the memory limitation of WAP devices certain desirable attributes are omitted from the digital certificate specifications, including the Serial Number and Issuer ID fields. A WAP Gateway is responsible for the translation of messages from one protocol to another. Just like it encodes text based WML content into binary WML format before sending it on its way on the air, it has to decrypt TLS encoded messages, convert the content into binary format, encrypt it using WTLS and then send it on its way. The same happens when the message arrives from the WAP device. It must be decrypted, decoded and the resulting WML re-encrypted using TLS specifications and then forwarded to the applications server. Consequently, the WAP Gateway sees all messages in clear text, including messages intended to be confidential throughout the transmission are exposed for a split second, and that is what is known as the WAP Gap, which can be addressed by setting up an internal WAP Gateway accessible only by Users of the application and configuring devices to use the new gateway for access to WAP content. Although some WAP devices support multiple gateway configurations, switching between them as the users navigate from one application to another is difficult. Most companies that deploy an end-to-end secure solution require their users to carry phones with pre-set gateway configurations and access to WAP applications hosted on their servers only. Despite the recent advent of WAP v. 2.0, this is currently this is the only known way to ensure end-to-end secure communications between a WAP device and an application server.
The web protocol used to communicate between the web-server and the micro-browser depends on the type of WID deployed. Some WIDs are capable of handling HTML such that they can be used for “direct access” to the web-server. Other WIDs are designed or setup to handle the more compact WML, such that, although their speed of operation is higher, they must access the web-server through a WAP Gateway making them subject to the WAP gap. Some conventional web-server implemented wireless services operate without encryption, while others use generic forms of encryption such as SSL or TLS, or deploy a 3 rd party VPN security product to connect to the service to the necessary web-server. FIG. 1 illustrates the prior art use of a wireless input device (“WID”) running a generic micro-browser the output for which is in WTLS, communicating by radio means, typically a cellular network, through an IAS Server that authenticates the wireless user who is provided with access to the internet, through a WAP gateway that must convert from WTLS to TLS before transfer over the Internet, to a web-server that is relatively exposed to attack because Port 80 remains “open” in order for a web-server to be accessible round the clock for requests from unknown sources, and by virtue of which crackers have a point of access to anything logically connected to web-servers. Use of such system to provide LAN Admin services is necessarily risky because the web-server must have access to the LAN in order to pass Admin instructions from a WID to any server on that LAN. It is therefore desirable not to use a web-server for network administration applications.
Proxy technology is well-known in the computing industries as a means to reduce the number of points of access by or to a LAN from the Internet. For example, commonly, proxy technologies are used as a “gateway” permitting client devices that are “sealed off” from the Internet a trusted agent that can access the Internet on their behalf, such gateway often running with a firewall positioned as a barrier to crackers. In the case of a proxy gateway the proxy technology has been applied as a “stand-in” or “proxy” for the client. In another example of a common use for proxy technology the “proxy” is applied for a server wherein caches of files that are popular are loaded onto a proxy server to fill requests for files originally from a machine that may be slower or more expensive to operate. In both cases, the true concept of proxy technology is based on a machine that actually does something on behalf of another machine, unlike a router that merely makes connections between end points permitting the machines at those points to conduct their own affairs.
FIG. 2 illustrates the prior art use of an intermediate server (as a router) to eliminate the use of a web-server and the WAP gap. However, even these newer technologies suffer a number of disadvantages. For example, such newer conventional means for wireless network admin rely on the generic, industry standard SSH protocol and its security layer SSL both of which are vulnerable to crackers. Further, SSH is interpreted character by character causing a large volume of data transfer and work on the client WID interpreting messages sent using the SSH protocol, neither of which is desirable in the narrow-bandwidth, low capacity world of portable computing devices. Similarly, SSL can only run on an SSL enabled WID and requires that security operations (as well as device management, and service functionality) be performed by the Managed Entity (e.g. a server on the LAN having business processes that it must run and that are thereby already consuming processor power or other system resources) running the SSH service. Consequently, even though some conventional SSH technologies include a machine intermediate the firewall and the LAN, that machine is restricted to operate as a router rather than as a true proxy, since its purpose (even though it may be implemented with some gateway functionality) is to provide a single point of entry through the firewall eliminating the need for a different port in the firewall to be opened for each Managed Entity requiring access to WID's outside the firewall.
Typically, an SSH based client is installed on each WID for communication with a machine that is not a web-server, but which merely (like a router) forwards network administration traffic without further processing, screening or handling—directly to the Managed Entities. Disadvantageously, in order to handle SSH-based traffic each Managed Entity must run an SSH service. The use of SSH to deliver OS level calls to each Managed Entity is very restrictive, limiting the variety of operations that may be executed from SSH without an additional soft agent to convert from and enhance the older style command line interface of SSH. SSH is also known as “Secure Shell”, a unix shell program for providing secure encrypted communication between untrusted hosts over an insecure network for the purpose of logging into, and executing commands on a remote computing device. However, although SSH is available as a service for Windows and Unix servers, if the SSH service is not running on the Managed Entity at the time access by the WID is required, or the Managed Entity is not responding at all (e.g. the administrative service is required because of a runaway process, or an overloaded CPU), then there is no way to communicate with the subject Managed Entity using SSH.
SSH is a limited industry standard protocol requiring a separate application to extend the number of commands that may be executed and the administrative work that may be performed when using it. And, although the SSH Command Line interface is very powerful, it is very keystroke oriented and requires a highly-skilled operator to apply it effectively, especially using the small keyboard and screen of a typical handheld WID. Although it is possible to write a program to run a WMI command within SSH and then use SSH to execute the program on a Managed Entity, it is very difficult to do. And, for standard admin applications that do not expose all functionality through the command line (e.g. accessing Windows mailbox's, rebooting a Windows server) it is very awkward to use those applications via SSH. Despite that macros or batch files can be written to reduce the typing required to execute a particular function, those macros must also be stored on the WID and the Managed Entity.
SSH is basically an encrypted version of TELNET, which are the only ways to remotely access UNIX servers for admin purposes—making them not only helpful, but also necessary. Unfortunately, SSH is also an extremely dangerous service to leave running on a server since its expert user, command line access design is very powerful and unforgiving—potentially allowing essential files to be deleted and wiped from drives that may also be reformatted with no “user friendly” warnings, backups, or means for recovery. Consequently, many network administrators will not permit SSH services to run on their networks and it is desirable to implement network administration without resort to SSH.
Disadvantageously, whenever the need to deliver these services wirelessly arises, Telnet and SSH are very powerful tools that can be misused to cause great disruption to the network on which they run. Conventionally, in order to access Telnet/SSH remotely there are three options: 1) open a port in the firewall for each managed entity, 2) use a server to act as a router, or 3) open one port for one TeInet/SSH server and have users Telnet/SSH from one server to another. In all 3 cases the security of the system relies on the strength of the well-known, well-understood SSH model based on a simple User ID and password. To enhance that conventional security model: the firewall can be configured to allow access to the Telnet/SSH port only via restricted IP addresses, or a VPN solution can be used to tunnel between a remote location and the Telnet server. Many companies find the firewall solution too restrictive and the VPN solution too complex or costly. Consequently, there is a need for a solution to securely deliver Telnet services remotely to a point behind a firewall for a reasonable price.
Authentication is the process of attempting to confirm whether an entity (e.g. a device or a User) is, in fact, what or who it has been declared to be. Authentication is commonly done using identifier (e.g. user name) password combinations, the knowledge of which is presumed to guarantee that the user is authentic. Each user's password is initially registered providing a measure of verification, however passwords can thereafter be stolen, intercepted, accidentally revealed, or forgotten. The more levels of authentication, the higher the level of confidence that the entity successfully providing all “keys” is authentic. Logically, authentication precedes authorization although they may often appear to be combined. Authorization is the process of confirming that an entity has permission to do or have something, for example, to give certain commands or to access to specific Managed Entities (e.g. servers) or files. A person of skill in the art would understand that authorization may take place at any or all of the network operating system (NOS), computer operating system (OS), or application levels.
Typically authentication takes place without encryption the keys for which may be negotiated once the host confirms the identity of the entity being authenticated. Typically authentication is carried out for the User alone and not for the device, which in the context of mobile devices has the disadvantage of permitting stolen devices to remain a threat against which there is no direct protection. It is therefore desirable to engage authentication means respecting mobile input devices. A hardware element commonly referred to as a “dongle” is one known means for uniquely identifying computing devices.
Integrity, in terms of data and network security, is the assurance that information has only been accessed or modified by persons authorized to do so. Common network administration measures to ensure data integrity include the use of checksums to detect changes to file content.
The OSI or “Open Systems Interconnection” model comprises seven (7) specific functional layers, being: Application, Presentation, Session, Transport, Network, Data Link and Physical. Two of those layers (Session and Transport) are particularly important to wireless network administrators because it is at these layers that security problems arise when using only the generic forms of processing, created for End Users (i.e. not Administrators) completing business transactions, are misapplied in order to enjoy flexible access for an Administrator's tool. IP is considered to be at the Network Layer, while TCP is at the Transport Layer. The higher level Application, Presentation and Session Layers (where FTP/SMTP/TELNET/SNMP/NFS/RPC run) combined are commonly referred to as the Process Layer, consequently FTP, SMTP, and TELNET are said to “run over” TCP and IP.
Transport Control Protocol (“TCP”) has been designed to be reliable, meaning that all (i.e. none missing) data packets will arrive in sequence and error-free. Internet Protocol (“IP”) has been designed to establish a “session” connecting remote stations and to maintain that session until all of the required data packets have been transferred. Although not all implementations of TCP/IP are alike, it is the use of a standard form of TCP/IP that permits a wide range of networks to share information regardless of the physical connection or hardware involved. Despite the difference between “dialects” of TCP/IP each dialect has a generic base that includes FTP (file), SMTP (mail) and TELNET (for terminal emulation). The combination TCP/IP is necessary to use the Internet to move commands between a mobile client and a managed entity—whether presentation is in HTML, WML, or through a GUI, and whether security is achieved using generic SSL, TLS, or WTLS, or through a security model—consequently, it is desirable to ensure that whatever is output by the WID is in a form that requires minimal processing to “run over” TCP/IP.
HTML and more recently XML are OSI Presentation Layer languages including a full suite of formatting commands recognized by generic browser clients for general use on modern desktops and other powerful machines having broadband access to the Internet. XML and WML are presentation language options neither of which is necessary unless a generic browser or microbrowser is involved in the system.
TLS is replacing SSL, in the OSI Transport Layer, as the industry standard for encryption when using TCP/IP to move packets securely across the Internet. Since most web content development now contemplates broadband access, in order to enhance performance on low power, limited capacity, narrowband wireless devices, WAP has evolved as a subset of rules permitting wireless devices to more efficiently access such graphics heavy content. WML (Wireless Markup Language) is a set of Presentation Layer commands based on XML and HTML, intended for use in specifying content (and a scaled down user interface) for narrowband devices for which reduced graphic content is appropriate. WTLS (Wireless Transport Layer Security) is the WAP variation on TLS available for use as the Transport Layer standard for generic security during the “wireless leg” of transmissions between a client and a managed entity. However, WTLS is not required for carrier dependent transmission to occur, which various implementations of WDP achieve without encryption being applied at the socket level. For example, a simple wireless device sending public information not needing to be encrypted could be used to send presentation instructions written in HTML to a web-server for display. The characters comprising the HTML would be processed for transmission in accordance with the radio carrier's particular radio network (and WDP) on the other end of which radio network they would be “de-processed” in preparation for uploading to “run over” TCP/IP across the Internet, without security. In the more common example of a sensitive message originating on a wireless device, characters written in WML (but they could be in HTML) would be encrypted at the socket level (as opposed to by the client application per se) using (generic) WTLS and then also processed in accordance with the carrier's particular radio network for transmission over the wireless portion of the journey to the message's destination. Upon reception at the radio carrier's tower, the message must be de-processed from the earlier radio network specific processing—and then also decrypted from WTLS (for conversion to TLS), since current technologies do not permit WTLS encrypted packets to be sent over the Internet on TCP/IP. Decryption from WTLS takes place on a WAP Gateway (typically supplied by an Internet carrier) that is inherently “public” in nature. It is during the time between the decryption from WTLS and re-encryption to TLS that a “gap” in security occurs that has become known as the “WAP gap”. During the interstitial period the characters in WML would sit in an unencrypted form on the WAP Gateway exposed to “sniffers” or other tools used by crackers to “listen” to known weak points in the Internet for subject matter of interest. Even though TLS and WTLS are “strong encryption” options, neither of them is necessary if an alternate means of security has been implemented to avoid the WAP gap. It is therefore desirable, particularly for network administration applications, to transmit information and commands using a system that does not rely on WTLS alone for security.
An application programming interface” (“API”) is the set of calling conventions by which an application such as a network administration client accesses the operating system (“OS”) and other services. There are currently 3 conventional programming interfaces that permit network operators to access Windows operating systems for the purpose of providing administrative commands to managed entities: WIN32, ADSI and WMI (CIM). Conventional remote administration technology delivers commands (e.g. reboot), through a web-server, using these interfaces directly to the managed entity that executes without further enquiry—such that a risk of the unauthorized deliver of such commands exists. A person of skill in the art would understand that various of these may be implemented as a Device Driver rather than a memory-resident program.
There are currently 3 main problems associated with using wireless technology to remotely administer a computing network. First, the need to transmit signals through open space creates a security problem because the signals are susceptible to interception. Second, the narrow bandwidth of current input device technology (e.g. pagers, PDAs, phones) makes data exchange slow. Third the fragile connectivity of current radio communication networks makes data exchange unreliable. Both slow and unreliable data exchange are severe practical limits on the administrative services deliverable.
To reduce the amount of data being transferred between a WID and its server, one conventional approach is to store more (LAN) information on the WID, which disadvantageously creates a serious security risk to the LAN in the event that the highly portable WID is stolen. It is therefore desirable to provide a solution that requires neither extensive transfers nor the storage of LAN data.
Conventionally authentication takes place without encryption the keys for which may be negotiated once the host confirms the identity of the entity being authenticated. Authentication is also carried out for the User alone and not for the device, which in the context of mobile devices has the disadvantage of permitting stolen devices to remain a threat against which there is no direct protection. It is therefore desirable to engage authentication means respecting the mobile input devices as well.
The prior art respecting the wireless administration of networks has concentrated on teaching variations on the application of generic access and security technologies.
SUMMARY OF THE INVENTION
The system aspect of the present invention avoids the use of a web-server and generic security to access a LAN, instead using a Message Processor that operates as a true Proxy device to pre-process all command traffic achieving several advantages. Said system is further enhanced by combining the foregoing novel method of using a Proxy with a novel security model and a novel messaging protocol for the secure Wireless Administration of Managed Entities, including the novel secure delivery of TELNET services across the Internet and behind a firewall.
The method aspect of the present invention uses a soft client installed on each WID for communication with a proxy server (avoiding the high risk use of a web-server) that is used to screen and otherwise pre-process all encoded traffic from each WID.
Advantageously, rather than merely forwarding network admin traffic to Managed Entities, the encoded messages are decrypted and the encoding “expanded” (i.e. the mapping is reversed) by the proxy into any suitable combination of standard WMI, ADSI, or WIN32 commands that are delivered directly to the OS of the appropriate Managed Entity, thereby eliminating a significant portion of the processing burden from each of the WID and the subject Managed Entity. Further, since the WID is not merely redirected so as to connect to a Managed Entity, it is not necessary to transfer the LAN identifiers (e.g. User ID and User Password) in the subject SSH message along with a command sequence. Further, without the complexity of and restrictions imposed by SSH, a full suite of OS level calls are available conveniently, thereby increasing the variety of operations that may be remotely executed on each Managed Entity by even less skilled Users.
A Wireless Input Device (“WID”) client must exchange information with a server (“Proxy”) in order for commands from the User of the WID to reach the devices (“Managed Entities”) being administered. The more information captured in each data packet exchanged, the fewer the packets the WID must prepare, send, receive, and process. Advantageously, to reduce the number of packets being transferred between the WID and the Proxy, the method aspect of the present invention uses a form of “shorthand notation” (basically overlaying a code on select commands that are organized in various sizes of groups of commands) according to which each message is encoded by applying a symbolic representation of one or more commands recognizable by the subject Managed Entity (e.g. for common computing devices this would include standard operating system commands). By so “encoding” the WID's transmission of common network commands (e.g. R9000=Get Key, R9001=Logon User) the resulting abstraction permits the Proxy to complete a significant amount of processing based on information that the WID is advantageously not required to store. For example, although the system of the present invention applies the well-known WIN32, ADSI and WMI programming interfaces (when administering LANS based on “Windows”), none of those network dependent collections of data are required to be resident on or handled by the WID.
Unlike simple macros or batch files, the “shorthand” of the present invention contains less than a full set of the information required to execute a particular operation (session transaction) that requires a number of individual (WMI, ADSI, WIN32) commands and parameters, which number depends on the particular operation. Only a code identifying each requested operation together with the parameters that must be supplied for that operation—are transmitted (after being protected according to the security model described below), and all processing that need not be done on the WID is done behind the firewall by the much more powerful Proxy server. The Proxy “expands” the shorthand by processing or interpreting the code into a sequenced list of individual commands together with the parameters necessarily supplied by the WID. Upon expansion, the Proxy can determine what further parameters (e.g. LAN Administrator ID and Password) it requires and obtain them, as well as take any precautionary (e.g. delay execution, or backup) steps that are appropriate based on the nature of the operation that it is about to instruct a Managed Entity to execute over the LAN. Upon the Managed Entity completing the requested operation, the Proxy may automatically execute a further series of network admin operations to locally confirm the status of the Managed Entity—all without requiring further intervention necessitating data exchange with the WID, instead reporting to the WID only the essential information remotely confirming status or requesting further input.
Advantageously, if intercepted, the codes and parameters are meaningless to anyone except the intended recipient and when received by the intended recipient provide both efficiency and additional security, because the Proxy identifies and expands the code into the associated block of interface commands and (parsed) parameters that it alone can submit directly to its Managed Entities.
According to one aspect of the invention, there is provided a method of encoding commands for the purpose of preparing an administrative message for transmission between a wireless input device and a Managed Entity, comprising the steps: map at least one command to an identifier comprising a first symbol, map at least one parameter to each said first symbol, map at least one value to each said parameter, create a first symbol-second symbol combination by appending a second symbol to said first symbol for the purpose of defining whether the transmission of said first symbol-second symbol combination is a request for or a confirmation of compliance, define a sequence according to which said first symbol-second symbol combination will be positioned within said message relative to said value of each said parameter, and assemble said message using said first symbol to represent at least one command recognized by said Managed Entity, and arranging said first symbol-second symbol combination together with said value of each said parameter in accordance with said sequence.
The security method aspect of the present invention is based on a combination of key management and prudent storage. Secret, Site, Communications and Session Keys, are applied together with Hashing and Tokens through an embedded client software application on the WID (any suitable computing, paging, phone, or other mobile device) that stores minimal information in an encrypted form and authenticates each of the User and the WID separately, advantageously making it possible to “lock out” stolen or missing WIDs. The novel use of a separate pass-phrase for the WID further strengthens authentication by making it harder for crackers to discover all of the elements that they require to attack a system. Even if a cracker were to obtain useful elements of access information, the subtle use of the software version number and other details shared between the WID and its proxy permit the system to select and switch key algorithms and hash functions periodically forcing crackers to “start over”.
By applying a number of different “keys” (some pre-shared, some generated as required) in sequence the additional layers of security resulting make it dramatically less likely that a cracker will intercept or otherwise acquire all of the elements necessary to gain access to an administered network in time to do any harm. A unique device ID and pass-phrase or PIN (a.k.a. MAN) for each WID make it possible to for a User to Logon with a measure of security already in place when the unique User ID and password or PIN, are submitted by the User. Further, the security that is then in place is rather than generic socket level security, which security is less familiar to crackers and may be changed from time to time (e.g. with new versions of the application) each adding a further barrier to unauthorized access. Advantageously, once device or User identity has been confirmed further authentication is implicit in the ability of the client to successfully engage any number of additional keys to communicate by encrypted means.
By also using passwords and pass-phrases as “seeds” to generate more complex “keys” for use in place of traditional passwords and pass-phrases, while never caching or otherwise storing passwords and pass-phrases per se, the resulting abstraction makes it substantially less likely that these necessary elements will be guessed, cracked, or otherwise discovered. In some cases a algorithm (that may be changed periodically) is supplied to each of the WID and the Proxy at the time the WID is initialized for the network to be managed, while in other cases a one-way Hash function is supplied to generate a very strong hash value based on a simpler User ID and User password, which ID and password therefore need not be stored on or transmitted from any mobile device.
Since when using a network administration application wirelessly, keys will be intercepted and crackers are motivated to break those keys to access the networks that the application is used to administer—there was a need (in addition to the Secret Key) for a Site Key that was both strong and unique to every installation of the application or even to each WID-Proxy combination at every installation. The problem was to find a way to reliably use a strong key between the WID and its Proxy, since all strong encryption keys include characters from the entire ASCII range, a majority of which are not available on a standard keyboard. And, even if keyboard input was an option, entering a 32 byte (256 bit) key is prone to human error, leading to significant usability issues. The solution of the present invention is to provide each WID-Proxy combination with a communications key algorithm to generate a Communications Key as needed, rather than to provide the key itself, which like certificates would need to be stored. This algorithm would combine the relatively simple and mnemonic WID ID and WID pass-phrase to generate a unique and relatively complex 32 byte (256 bit) key that if intercepted would be much more difficult for a cracker to access and use. Since the communications key algorithm is loaded onto the WID and its Proxy, and is never legitimately transmitted, the algorithm is at low risk of being available to crackers by interception or otherwise. Further, since the WID pass-phrase is never transmitted, even upon intercepting the key a cracker has insufficient information from which to reverse engineer the elements required to spoof the WID in order to gain access to the Proxy that sends commands to the Managed Entities.
By further using identifiers (e.g. ID and password or pass-phrase) that are unique to the network administration service, no LAN related access information is required by the mobile WID. Although the method and system aspects of the present invention are compatible with and contemplate the option of allowing LAN access information being used rather than identifiers unique to the service, advantageously the isolation permitted by the use of unique identifiers makes it less likely that a cracker may intercept LAN information useful for attacking the subject LAN even outside the wireless environment. Further, since WIDs are commonly lost or stolen, no identifiers or LAN information are stored or even cached on the WID, and the WID ID and WID pass-phrase are stored on the WID only in a database that is maintained in an encrypted (typically using the Secret Key) form.
By further using tokens to validate each transaction (or operation) within a session, “replay” attacks may be prevented. Once authentication and authorization are complete a session may commence secured by the session key supplied by the Proxy together with a first token that must be returned by the client to complete the next transaction (e.g. Logon User). Although an ACK response must also sent from the WID to the Proxy each time a packet is received, advantageously, according to the security method of the present invention a valid token must accompany each transaction including commands that the User wishes to execute—and the Proxy will not deliver the commands (extracted from the message) to any Managed Entity until a valid token is supplied by the WID. Advantageously, to prevent spoofing a transaction will be denied if the token returned by the WID does not match the token provided to the WID. If more than one valid token (maintained in an array in the order that they are generated) has been sent by the Proxy, then all of the prior tokens will expire or be cancelled by the Proxy upon its receipt of a more recent token. The Proxy also removes all prior tokens from the array when confirmation of receipt of a transaction is received, which is indicated by receipt from the WID of the ACK respecting the final packet of the subject transaction.
The novel use of the ACK “handshake” addresses the problem of dropped packets without flooding the network with unsolicited resends. After a configurable time (e.g. 10 minutes) the Proxy will terminate the session unless it receives an ACK from the WID. Similarly, the WID may request a resend of a packet that it was expecting (e.g. due to an EOB suggesting that the message has been broken into blocks) but had not yet received.
By further isolating the Managed Entities from the WID, using an intermediate message processor (e.g. a proxy server) to receive, decrypt and decode all encrypted and encoded messages from the WID, details respecting the existence of the Managed Entities become less readily available—making them more difficult to “see” as prospective subjects for an attack.
A person of skill in the art would understand that security is further enhanced by embedding the client software application into the WID and providing it with data that is never transmitted, while also imposing IP port and address restrictions and encrypting all necessary transmissions, further providing SSH and NTLM authentication, and a full audit trail and logging of all activity on every Proxy and every WID making it easier to identify security problems.
According to one aspect of the invention, there is provided a system, for securing communication between a WID and a Proxy having access to an encrypted service database for storing information respecting said WID and information respecting at least one User of said WID, comprising: an identifier for said WID, stored encrypted on said WID and stored unencrypted in said service database, a password for said WID, stored encrypted on said WID and in said service database, a secret key pre-shared between said WID and said Proxy, a site key for encrypting said service database and decrypting said password for said WID stored encrypted in said service database, a communications key algorithm using both said identifier for said WID and said password for said WID, for the purpose of generating a communications key, a first message for the purpose of said WID requesting a connection to said Proxy, said first message comprising two parts, one part including said identifier for said WID encrypted with said secret key, and a second part including an encoded command and parameters for said command, said second part encrypted with said communications key, a session key for encrypting messages after a session is established, at least one token for validating messages within a session, and a second message for the purpose of said Proxy providing to said WID said token and said session key, said second message encrypted with said communications key, whereupon the receipt of said token and said session key said WID is enabled to provide at least one further message to said Proxy by returning said token within said message to said Proxy.
According to another aspect of the invention, there is provided a system further comprising: an identifier for said at least one User of said WID, stored unencrypted in said service database, a password for said at least one User of said WID, stored as a hash value in said service database, a hash value resulting from hashing said identifier for said User with said password for said User, said hash value for substituting in place of said password for said User, and a third message for the purpose of securely authenticating and authoring said User.
The method and system aspects of the present invention use and include a true proxy server (“Proxy) element intermediate the WID and the Managed Entity, advantageously thereby minimizing the processing burden on the WID and the Managed Entity.
By running substantially the entire administration service on the Proxy (typically behind a firewall), rather than on any Managed Entity, even when a Managed Entity is “off line” the method of the present invention experiences a high probability of being both available and useful, since the Proxy can deliver low level commands to the operating system of the subject Managed Entity forcing it to reboot or shutdown if other commands would not be effective in restoring operation. Further, by implementing a true proxy method of providing administrative services, not only is there a single point of entry through the firewall to the LAN, but the Proxy may pre-process every message before it reaches any Managed Entity on the LAN, thereby off-loading the burden of message processing from the WID and the Managed Entities to a potentially more powerful machine dedicated to authentication, interpretation, authorization, and queuing all traffic created or requested by WIDs.
Advantageously, the system aspect of the present invention further implements a GUI to an embedded client application that may be used to deliver WMI, ADSI, Win32, Telnet, SSH and other commands through a common and familiar interface accessible to a wider range of User including less skilled operators in the event that a preferred Network Administrator is not available in a timely manner. The system of the present invention is capable of (without the industry standard cryptic SSH Command Line interface considered unfriendly to legitimate but less-skilled operators) performing operations that an SSH based system could perform—but does so through an easier to use (i.e. less prone to error) interface that also accesses operations an SSH system cannot. Even where commands are (to reduce the keystrokes on the WID) grouped or batched, the macros or other means for such grouping are interpreted on the Proxy rather than stored on the Managed Entity.
Advantageously, as compared to SSH-based technology, the system aspect of the present invention requires no services (unless TELNET or SSH is desired) to be run on the Managed Entities and unlike a router processes, screens and other wise handles all network administration traffic before it is delivered to the Managed Entities.
Delivery of Secure TELNET Services Behind a Firewall
Advantageously, the system aspect of the present invention further makes it possible for Telnet Services to be delivered securely from a wireless device and across the Internet to or from a Managed Entity behind a firewall by using the proxy technology described herein. Given that the WID is never connected directly to the subject Managed Entity, advantageously, among the functionality that the WID can request that the proxy provide on its behalf, is a Telnet/SSH connection. If the Telnet/SSH service is already running on the ME, since the LAN related User ID and User password are already stored on the proxy (i.e. do not have to be transmitted) they may be supplied to the ME and any Telnet/SSH commands mapped to the novel messaging protocol described in detail above will be encoded at the WID for decoding at the proxy and then sent to the ME after being authorized in exactly the same manner as all other commands are handled according to the method and system of the present invention. In a particular installation only a subset of Telnet/SSH commands may be mapped to the messaging protocol of the present invention, or the proxy may be used during authorization to restrict access to particular Telnet/SSH commands to particular Users respecting particular Managed Entities.
Advantageously, the apparatus aspect of the present invention in the Soft Agents for use on each of the wireless input device and proxy server ends of the communication process are provided to the User through a menu driven GUI novel to wireless Network Administration, as well as self-installing and easily configured. Moreover a single installation of the service of the present invention permits management of all connected managed entities, even across multiple domains. Importantly, no software agents need to be installed on any of the managed entities. The method and system of the present invention permit a full but configurable range of functionality, including: view, move, cut, copy and paste files; view and edit text files (e.g. Boot.ini, batch files, html, etc); e-mail (“send to”) files from a managed entity; monitor the services and processes on any managed entity; stop, start, restart or pause services and kill bad processes; logoff, shutdown, or force-reboot any managed entity; generate and run custom scripts and batch files; control power to any external device including servers, switches, hubs, modems; and execute any command line instruction securely allowing control of any network device that supports SSH or Telnet, including: Unix, Linux, routers, hubs, print servers.
According to one aspect of the invention, there is provided a method, for a User to wirelessly administer at least one Managed Entity, comprising the steps: transmit an encoded message, including commands for said Managed Entity, from a wireless device, receive and decode said message on a message processor trusted by said Managed Entity, authenticate said device and authorize said commands on said message processor, and send authorized commands from said message processor to at least one Managed Entity. Further wherein said Managed Entity comprises a server connected to a LAN and said wireless device comprises a portable digital computing device having access to the Internet through a radio network. Further wherein said transmission of said message is via wireless or internet means or a suitable combination thereof. Further wherein said commands are adapted for execution by the operating system of said Managed Entity. Further wherein said message is encoded by applying a symbolic representation of groups of commands or an encryption of said representation (or both) for the purpose of making said message smaller in size or more difficult to access. Further wherein said decoding comprises: decrypting, interpreting, and expanding said message to a list of said commands suitable for transmission from said server to said Managed Entity. Further wherein said authentication and authorization are completed by said server acting as a proxy for at least one said Managed Entity. Further wherein said authentication comprises confirming that said device is a device registered on said server or said User is a User registered on said server. Further wherein said authentication comprises confirming that said device is a device registered on said server and said User is a User registered on said server. Further wherein said authorization comprises confirming that said User is permitted to require said Managed Entity to execute said commands. Further wherein said transmission of said authenticated and authorized commands from said server to said Managed Entity is completed without any connection between said device and said Managed Entity.
According to a further aspect of the invention, there is provided a System, for a User to wirelessly administer at least one Managed Entity, comprising: means for creating and transmitting an encoded message, including commands for said Managed. Entity, from a wireless device to the internet, means for receiving said message, a message processor, trusted by said Managed Entity, on which to receive and decode said message, means for authenticating said device and authorizing said commands on said message processor, and means for sending authorized commands from said message processor to at least one Managed Entity. Further wherein said means for creating and transmitting an encoded message from a wireless device, comprises a First Soft Agent operating on a radio network enabled transmitting device, including a cell phone or a pager, further having means of access to the internet. Further wherein said means for receiving said message comprises a connection to the internet adapted for use by said message processor. Further wherein said message processor comprises any server, not having Port 80 open, but adapted for connection to the internet as well as to the network on which said Managed Entity operates, and for which suitable access rights have been granted. Further wherein said means for authenticating said device and authorizing said commands on said message processor comprises a Second Soft Agent operating on said message processor. Further wherein said means for sending authorized commands from said message processor to at least one Managed Entity comprises a connection to said LAN.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate preferred embodiments of the method, system, and apparatus according to the invention and, together with the description, serve to explain the principles of the invention.