The present invention relates to the routing of data between a client computer and one or more resources through a network. Various aspects of the invention may be used to help ensure that data, exchanged between a client computer and resources in a remote network, is routed using network addresses that do not conflict with addresses local to the client computer.
In the last decade, the use of electronic computer networks has greatly increased. Electronic computer networks may be found in businesses, schools, hospitals, and even residences. With these networks, two or more computing devices communicate together to exchange packets of data according to one or more standard protocols, such as the Transmission Control Protocol/Internet Protocol. Usually, one computer, often referred to as a “client” or “client” computer, requests that a second computer perform a service. In response, the second computer, often referred to as a “server” or “server” computer, performs the service and communicates the resulting data back to the first computer.
As reliance on computers has increased, the demand to access computer resources from a variety of locations has increased as well. Conventionally, for example, a business user may have accessed resources on a corporate server through a desktop computer connected to the corporate server by a private, secure corporate network. Now, however, that user may wish to access the same corporate resources from a remote location over a public network, such as the Internet. For example, a user may need to access resources through a corporate network from a personal computer while at home or from a laptop computer while traveling. In order to securely access these network resources, the user will typically employ an encrypted communication technique. The connection formed by the client computer and a server computer (or by the client computer and another network available through a server computer) often is referred to as a Virtual Private Network (VPN).
A virtual private network can be formed using a plurality of different encrypted communication techniques. For example, a client computer may implement a temporary or permanent dedicated communication software application to securely communicate with a server computer. The dedicated communication software application will then encrypt and send messages to the server computer, and receive and decrypt messages received from the server computer. Some examples of this type of dedicated communication software application may embed encrypted messages in conventionally formatted data packets, so that the encrypted messages are unreadable from outside of the secure communication channel. The virtual private networks that employ these embedded communication techniques are sometimes referred to as “tunneling” virtual private networks, because their communications appear to “tunnel” through a public network such as the Internet.
It also should be appreciated that, with some implementations of a virtual private network, the client computer can communicate point-to-point with some or all of the nodes within another network available through the server computer. With still other implementations of a virtual private network, however, the client computer may directly communicate with only a proxy software application on the server computer. The proxy software application will then decrypt communications from the client computer, and route them to the appropriate node within the network. With this type of virtual private network, the proxy software application may be hosted on a computer (or computing node) outside of a firewall protecting the rest of the network. The proxy software application communicates with network nodes through the firewall. Different types of virtual private networks may employ any desired encryption technique. For example, a virtual private network may implement communication channels secured using the Secure Socket Layers (SSL) protocol, the Hypertext Transfer Protocol Secure (HTTPS) protocol (which employs the Secure Socket Layers (SSL) protocol), or the Internet Protocol Security (IPSec) protocol.
While a virtual private network can provide a client computer with secure access to remote resources through a network, the network addresses for the remote resources may conflict with local network addresses. For example, a user may purchase a cable modem or local router for a home network which uses the IP address range 192.168.x.x. Many commercial systems also use this IP address range of 192.168.x.x, however. Accordingly, when the user's computer attempts to access a resource in a remote network, such as a corporate network maintained by the user's employer, the address of the resource on the remote network may conflict with a local resource on the user's home network. For example, in some situations, a server on the remote network may allocate addresses to the client computer for accessing one or more resources on the remote network. If one of these network addresses conflicts with the network address for the network interface card (NIC) of the client computer, the conflict may prevent the client computer from accessing any external resources. As a result, an address conflict may prevent the user's computer from accessing a desired resource in the remote network, or even access a local resource.
Accordingly, it would be desirable to be able to resolve network address conflicts between a client computer's local resources and the resources on a remote network. Further, it would be desirable to resolve conflicts without overwhelming the routing table provided on the client computer or creating unnecessary conflicts within the routing table.
Various aspects of the invention relate to techniques for resolving address conflicts between network addresses for resources that are local to a client computer and network addresses for resources in a remote network. With some implementations of the invention, for example, the client computer hosts a virtual private network tool to establish a virtual private network connection with a remote network. Upon startup, the virtual private network tool collects address information from the network interfaces of the client computer. For example, the virtual private network tool may obtain, for each network interface, the IP address for local resources such as the local gateway, Domain Name System (DNS) servers on the local network, Windows Internet Naming Service (WINS) servers on the local network, and the like. The virtual private network tool then sends this local resource address information to an address assignment server in the remote network.
The address assignment server has access to a pool of addresses that are available for use by nodes in the remote network. When it receives the local resource address information from the client computer, the address assignment server compares the addresses in the local resource address information with the pool of addresses for the remote network. The address assignment server then will select addresses for use by the client computer that do not conflict with the addresses for local resources. For example, the client computer may employ a virtual network interface card (also known as a virtual network adapter or just virtual adapter) to act as a node of the remote network. The address assignment server will select an virtual IP address for the virtual network adapter that will not conflict with the IP address of the physical network adapter being used by the client computer.
The address assignment server also has access to a list of resources in the remote network that are available to the client computer. When the client computer joins the remote network, the address assignment server provides routing information for these remote resources to a virtual private network tool hosted by the client computer. The virtual private network tool will postpone loading this routing information into the routing tables for the client computer, however, until the client computer requests access to a specific resource in the remote network. When the client computer does request access to a specific resource in the remote network, the virtual private network tool will only provide the routing table with the routing information for that specific remote resource. In this manner, address conflicts between local resources and remote resources can be avoided until the client computer requests access to a remote resources address that actually conflicts with a local resource address.
Client/Server Configuration
Various embodiments of the invention will typically be employed to facilitate cooperation between a client and one or more servers in a remote network. As known in the art, a client/server configuration (including a Web-based architecture configuration) occurs when a computing device requests the use of or access to a resource from another computing device. For convenience and ease of understanding hereafter, requests to use, obtain, or otherwise access a resource may generically be referred to simply as “requesting” a resource, while using, obtaining, or otherwise accessing a resource may generically be referred to simply as “obtaining” or “accessing” a resource. Because the computing device responsible for providing the resource “serves” the computing device that initially requests the resource, the computing device responsible for providing the resource often is referred to as a “server.” The computing device initially requesting the resource then commonly is referred to as a “client.”
It should be noted that, as used herein, a server may be considered a virtual device rather than a physical device. For example, the functions of the server 103 may be performed by a single computing device. Alternately, the functions of the server 103 may be performed by a group of computing devices cooperating together. Similarly, a client may be considered a virtual device. That is, one or more separate computing devices can cooperate together to function as a client. In many situations, a client computer may work with multiple server computers in a remote network to access a resource. For example, a client computer may submit the request for a resource to a first server computer, which may then relay the request though the remote network to a second server computer. The second server computer may authenticate the identity of the client computer (or a user employing the client computer), to determine whether the client computer has permission to access the requested resource. Yet another server computer in the remote network may then actually provide the client computer with access to the requested resource.
As used herein, a resource may be any type of object or service available through a server computer. For example, a resource may be a data file or a directory of data files. A resource may also be a service, such as an electronic mailing service, a database service, a document management service, a remote shell or terminal service, or any other service provided by an executing software application. Further, a resource may be within a network, or it may be located outside of a network but accessible to the client computer through a network.
Example Computing Device
Various embodiments of a virtual private network according to the invention may be implemented using dedicated analog or digital electronic circuitry. More typically, however, the various features of the invention will be implemented by executing software instructions on a programmable computing device or computer. For example, each node in a virtual private network will typically be implemented by executing software instructions on a programmable computing device or computer. Accordingly,
The computer system 201 illustrated in
A number of program modules may be stored on the ROM 209, the hard disk drive 215, the magnetic disk drive 217, the optical disk drive 219 and the flash memory reader 221. A user may enter commands and information into the computer system 201 through an input device 223, such as a keyboard, a pointing device (e.g., a mouse, touchpad, joystick trackball or the like), a touch screen, a microphone or any other suitable interface device. Of course, the computer system 201 may simultaneously employ a variety of different input devices 223, as is known in the art. One or more output devices 225, such as a monitor or other type of display device, typically will also be included to convey information from the computer system 201 to the user. As will be appreciated by those of ordinary skill in the art, a variety of combinations of output devices 225, such as displays, speakers and printers, may be included in the computer system 201. The computer system 201 also may have one or more device interfaces 227. A device interface may be any suitable interface for transferring data to or receiving data from another device, such as an RS-232 port, a USB port, a PS2 port, an infrared or Bluetooth wireless port, or the like. It should be noted that, with various examples of the computer 201, one or more of the input devices 223 and the output devices 225 may be connected to the system bus 207 through a device interface 227.
In order to access other computing devices, the computer system 201 should be capable of operating in a networked environment using logical connections to one or more remote computing devices, such as the device interface 227. Accordingly, the computer 201 may include a network interface 229. The network interface 229 may be implemented, e.g., using a conventional Network Interface Card (NIC) (also sometimes referred to as a network adapter). The computer 201 may have a wired network interface 229, a wireless network interface 229, or any combination of the two. For example, the computer 201 may have two wired network interfaces 229 and a single wireless network interface 229. The computer system 201 then can connect to a local area network (LAN) 231 through the network interface 229. Alternately or additionally, the computer 201 may connect to a wide area network (WAN) 233, such as the Internet, through the network interface 229.
Using the network interface 229 to connect to a LAN 231 or a WAN 233, the computer may communicate with another, external computer 235 (or other computing device). As used to describe various examples of the invention herein, if the computer 201 communicates with an external computer 235 in a remote network for which WAN 233 acts as a pathway, then that external computer 235 may be referred to as a “remote” computer. Other computing devices that are not in the remote network may then be referred to as “local” devices.
A Virtual Private Network System
The client computer 301 also includes a virtual network adapter 313 and IP router/routing table 315. As will be appreciated by those of ordinary skill in the art, the virtual network adapter 313 is implemented by the execution of software instructions that simulate the operation of a physical network interface card. With some examples of the invention, the virtual network adapter 313 will be instantiated by the virtual private network tool 311. With alternate examples of the invention, however, the virtual network adapter 313 may be independent of the virtual private network tool 311. The IP router/routing table 315 stores routes, in the form of network addresses, for accessing local and remote resources. As will be explained in more detail below, the software application 309 will employ routes in the IP router/routing table 315, populated by the virtual private network tool 311, to access resources through the remote network 303. The operating system 307 then manages the operation of the software application 309, the virtual private network tool 311, the virtual network adapter 313, and the IP router/routing table 315.
The remote network 303 includes an authentication server 317, an address assignment server 319, one or more Domain Name System (DNS) servers and/or Windows Internet Name Service (WINS) servers (collectively referred to as DNS/WINS server 321), policy rules 323, and a pool 325 of network addresses. Each of the DNS/WINS servers 321 translates a host name (corresponding to a resource) into a network address. For example, a DNS server may translate a domain name, such as mycompany.com, into the network address corresponding to the computer hosting that domain name, such as 192.68.42.12. The authentication server 317 authenticates the identity and, with some examples of the invention, the operating environment of the client computer 301. Based upon a successful authentication, the authentication server 317 will then establish a secure connection tunnel with the virtual private network tool 311 in the client computer 301. The connection tunnel may be, for example, any type of virtual private network connection. Thus, the authentication server 317 may establish a virtual private network connection tunnel with the virtual private network tool 311 using the Secure Sockets Layer (SSL) protocol.
As will be explained in more detail below, the authentication server 317 (or a separate policy server, not shown) compares the authentication information for the client computer 301 with access policies set by a network administrator or other authorized person, in order to determine which addresses in the remote network are available for use by the virtual network adapter 313. These addresses are then included in the address pool 325.
Once the authentication server 317 (or a separate policy server, not shown) has determined the addresses that can be used by the virtual network adapter 313, the address assignment server 319 will compare local network information for the client computer 301 with the available network addresses in the address pool 325, to determine whether any of these addresses will conflict with local addresses for the client computer 301. It then assigns addresses to the virtual network adapter 313 that do not conflict with the provided local network information.
The remote network 303 also includes one or more resources 327. The resource 327 may be implemented by any server or combination of servers responsible for providing one or more resources 327 to client 303. For example, the resource 327 may be a Domain Name Service (DNS) server, an electronic mail server, a server that maintains a database, a print server, a data storage server, a file or document management server, a Voice over Internet Protocol (VoIP) server, a remote shell or terminal service or the like. With some implementations of the invention, the resource 327 may only be indirectly responsible for providing requested resources. For example, the resource server 327 may be a proxy server providing a connection to yet another server through, for example, a private network, which will actually provide the requested resources to the client 303. It should be noted that a resource 327 may be located within the remote network 303. Alternately or additionally, a resource 327 may be accessible by the remote network 303 through a public network 305, such as the Internet, or by a private network 329 as shown in
With various examples of the invention, the authentication server 317 (or a separate policy server, not shown) also compares the authentication information for the client computer 301 with the access policies to determine which of the resources 327 may be accessed by the user of the client computer 301 (or by a user of the client computer 301 or the software application 309 in particular). Based upon these access policies, the authentication server 317 (or a separate policy server, not shown) will create the policy rules 323 for the resources 327. From these policy rules 323, the address assignment server 319 will then generate VPN routing rules for providing routing information to the IP router/routing table 315 in the client computer 301, and send these VPN routing rules to the virtual private network tool 311.
Configuration of the Virtual Network Adapter
As will be appreciated by those of ordinary skill in the art, the virtual network adapter 313 operates through a physical network adapter 229, such as a network interface card (NIC). In some examples of the invention, the physical network adapter 229 serves as a node in a local area network (LAN), such as a user's home network, a network maintained by, e.g., a hotel, airport, office, coffee shop, Internet cafe or the like. After the virtual private network tool 311 has established a virtual private network connection with the remote network 303, the virtual network adapter 313 then may serve as a wide area network (WAN) node in the remote network 303. Thus, the virtual network adapter 313 may “tunnel” through a local area network to act as a WAN node in the network 303.
Because the virtual network adapter 313 operates through the physical network adapter 229, however, the network information used by the virtual network adapter 313 cannot conflict with critical network information for the physical network adapter 229. For example, the virtual IP address (VIP) of the virtual network adapter 313 cannot be the same as the IP address being used by the physical network adapter 229. Accordingly, the virtual network adapter 313 should be configured using network information that does not conflict with critical network information being used by the physical network adapter 229.
Next, in step 403, the authentication server 317 authenticates the client computer 301 (or a user employing the client computer 301). With some implementations of the invention, this may be a simple identity authentication using any desired conventional techniques, such as the exchange of encryption key information. As will be discussed in more detail below, however, alternate implementations of the invention may employ the rule-based routing system described in U.S. patent publication No. 2006-0143703, entitled “Rule-Based Routing To Resources Through A Network,” naming Chris Hopen et al. as inventors and filed on Oct. 14, 2005, which application is incorporated entirely herein by reference. As discussed in detail in that application, the authentication information is compared with access policies set up by a network administrator or other authorized person. Based upon this comparison, policy rules 323 are created which control which resources 327 may (or may not) be accessed by the client computer 301 (or, with some implementations of the invention, by the user of the client computer 301 or by a specific application 309 hosted on the client computer 301). With some examples of the invention, these access policies also may be used to determine which available network addresses should be included in the address pool 325.
Once the client computer 301 has been authenticated, the virtual private network tool 311 collects critical network information for the client computer 301 in step 405. As previously noted, the virtual network adapter 313 will be tunneling through a physical network interface card 229. To avoid conflicting with the operation of any physical network adapter 229 being used by the client computer 301, the virtual private network tool 311 obtains the critical network information for each physical network adapter 229. For example, if the virtual network adapter 313 is tunneling through a physical network interface card 229 connected to a local area network, then the critical network information obtained by the virtual private network tool 311 will include the Internet protocol (IP) address and the subnet for each physical network adapter 229 being used by the client computer 301. It also will include the IP address of the default gateway being used by the local area network, and the IP addresses of the DNS and/or WINS servers that are used by each physical network adapter 229 to resolve domain names. Also, if a physical network adapter 229 is using the Dynamic Host Configure Protocol (DHCP) to obtain a network address, then the network address of the DHCP server providing the network address will be included in the critical network information. With some implementations of the invention, the critical information also may include the domain suffix for the local area network.
The virtual private network tool 311 may identify the critical network information using any desired technique, such as by querying application programming interfaces (APIs) provided by the operating system 307 for network interface configuration. This operation will be analogous to using the “ipconfig/all” command available windows command provided by the Windows operating system available from Microsoft Corporation of Redmond, Wash. It should be appreciated, however, that various techniques for identifying the critical information will be well known to those of ordinary skill in the art, and any suitable technique may be employed. It also should be appreciated that the specific critical network information may vary depending upon, for example, the configuration and use of each physical network adapter 229.
Once the critical network information has been collected, the virtual private network tool 311 provides the collected information to the address assignment server 319 in step 407. In response to receiving the critical network information (and any other provided state information) for the client computer 301, the address assignment server 319 analyzes the address pool 325 in step 409 to determine non-conflicting network information that can safely be used to provision the virtual network adapter 313 for operation. For example, the address assignment server 319 will assign a virtual IP (VIP) address for the virtual network adapter 313. It also will assign at least one name service host address, such as an address to a DNS server 321, and corresponding routing information for the assigned name server host address. If the address assignment server 319 cannot assign network information to provision the physical network adapter 229 without conflicting with the critical network information, then the address assignment server 319 sends an error message to the client computer 301 and terminates the process.
In some implementations of the invention, the address assignment server 319 may assign network information for use by the virtual network adapter 313 that conflicts with non-critical network information, such as the network address of a local DNS server among a plurality of DNS servers being used by the physical network adapter 229. These examples of the invention may then identify these conflicting addresses in, e.g., a log, which can be sent to the virtual private network tool 311 for use by the client computer 301.
As previously noted, some implementations of the invention may employ the rule-based routing system described in U.S. patent application Ser. No. 11/251,592. As discussed in detail in that patent application, the remote network 303 may employ the authentication server 317 a separate policy server (not shown) to create policy rules 323 that control access to resources 327 within the network 303. These policy rules 323 may be based upon, for example, access privileges assigned to the client computer 301, a community of which the client computer 301 is a member, the identity of the person using the client computer 301, the application 309 seeking access to the resource, the computing environment in which the client computer 301 is operating or any combination thereof.
With these implementations of the invention, any name service host address assigned for use by the virtual adapter 313 will be obtained from the policy rules 323 (i.e., any assigned name service host address will be identified as an accessible resource 327 in the policy rules 323. Also, if the policy rules 323 prohibit the client computer 301 from using one or more addresses in the pool 325, then it is irrelevant whether or not these addresses will conflict with either the critical network information or addresses for other local resources of the client computer 301.
Next, in step 411, the address assignment server 319 determines the connection mode for the connection tunnel. The connection mode, which typically is set by the network administrator, may be a “redirect all” mode or a “split tunnel” mode. In the redirect all mode, the address assignment server 319 can override the addresses for the DNS and WINS servers that normally would be used by each physical network adapter 229 by allocating the virtual network adapter 313 conflicting addresses for the IP router/routing table 315, along with rules giving precedence to the assigned addresses of the DNS/WINS servers 321. In this mode, all data sent through the virtual network adapter 313 will be redirected to the remote network 303.
For the split tunnel mode, the address assignment server 319 can override all of the addresses for DNS and WINS servers that normally would be used by each physical network adapter 229, except for one. This arrangement allows the client computer 301 to achieve both virtual private network and non-virtual private network split tunneling through the virtual network adapter 313 and physical network adapters 229 respectively. Thus, the address assignment server 319 will identify and allocate one set of addresses for the DNS/WINS servers 321 that do not conflict with the addresses for DNS and WINS servers that normally would be used by the physical network adapters 229.
In the split tunnel mode, the address assignment server 319 may have to eliminate the addresses of one more of the DNS/WINS servers 321 to avoid a conflict with the one required address for a DNS server and a WINS already employed by the client computer 301. For this reason, split tunnel mode will not work with a single pair of DNS and WINS servers 321 and a single pair of DNS and WINS servers employed by the client computer 301, respectively, that conflict. If this situation occurs, an error message is generated to the client computer 301, and the process ends.
In step 413, the address assignment server 319 then establishes the VPN routing rules that will be used to add routing information to the IP router/routing table 315 for accessing the resources 327. More particularly, the address assignment server 319 will prepare VPN routing rules based upon the policy rules 323 to control how routing information for the resources 327 is added to the IP router/routing table 315. With various examples of the invention, each VPN routing rule will contain a resource identifier value and a permission value. The resource identifier value may be an IP address or a fully qualified domain name that identifies a single resource 327. The resource identifier value also may identify a set of one or more resources 327. That is, the resource identifier value also may be a partially-qualified domain name or a plurality of IP addresses, expressed either as a subnet or a range of IP addresses.
With some examples of the invention, the permission value will only be an “inclusion” value, indicating that the resource or resources 327 identified by the resource identifier value can be accessed by the client computer 301 via the remote network 303. Some implementations of the invention, however, may also allow the permission value to be an “exclusion” value, indicating that the resource or resources 327 identified by the resource identifier value cannot be accessed by the client computer 301. (It should be noted that an “exclusion” value in a VPN routing rule does not exclude a resource 327 from being accessed using a different mechanism separately from the remote network 303, such as through a local area network or through a separate wide area network.)
As discussed in U.S. patent application Ser. No. 11/251,592, an exclusion rule will take precedence over an inclusion rule. Thus, if one VPN routing rule indicates that a client computer 303 may access any resource 327 in a domain “yourcompany.com,” but another VPN routing rule indicates that the client computer 303 may not access the resource 327 named “accounting.yourcompany.com,” then the client computer 301 will be prohibited from accessing the resource 327 named “accounting.yourcompany.com.” Also, with various examples of the invention, a VPN routing rule having a more specific resource identifier value (e.g., network address 128.20.1.12) will take precedence over a VPN routing rule having a more generic resource identifier value (e.g., a subnet address 128.20.1.0).
In step 415, the virtual private network tool 311 activates the virtual network adapter 313. That is, the address assignment server 319 provides the provisioning network information to the virtual private network tool 311. The virtual private network tool 311 then registers the provisioning network information with the operating system 307 to activate the virtual network adapter 313, and its interface address information is bound to the IP router/routing table 315. Then, in step 417, the address assignment server 319 provides the VPN routing rules to the virtual private network tool 311 for subsequent use in accessing the resources 327, as will be described in more detail below.
Employing the VPN Routing Rules
With some implementations of the invention, the virtual private network tool 311 could provide all of the routing rule information to the IP router/routing table 315 at one time. Depending upon the size of the VPN routing rules, however, this might greatly increase the overhead required to maintain and search the IP router/routing table 315. Moreover, the VPN routing rules could introduce unnecessary address conflicts to the IP router/routing table 315 for resources 327 that may never be requested by the client computer 301. Accordingly, with various embodiments of the invention, the virtual private network tool 311 initially will only provide the IP router/routing table 315 with the VPN routing rules for accessing name service hosts in the remote network 303, i.e., the DNS/WINS servers 321. When the application 309 submits an address resolution query to one or more of the DNS/WINS servers 321 through the virtual network adapter 313, the query reply is monitored to determine what additional routing information should be provided to the IP router/routing table 315. Similarly, when the application 309 provides an IP address to the operating system 307 to access a resource 327, the IP address is monitored to determine what additional routing information should be provided to the IP router/routing table 315.
Turning now to
In step 609, the name filter 501 searches the VPN routing rules to locate the routing information corresponding to the name of the requested resource 327. In step 611 the name filter 501 then expands the VPN routing rules maintained in the virtual private network tool 311 to include VPN routing rules specific to each network address returned by the DNS/WINS server reply. More particularly, if the VPN routing rules indicate that the client computer 301 can access the requested resource 327, then the name filter 501 will generate a corresponding VPN routing rule for each network address identified in the reply. If, however, the VPN routing rules indicate that the client computer 301 is not permitted to access the requested resource 327, then the name filter 501 will take no action. The name filter 501 then releases the reply returned by the DNS and WINS servers 321 to the application 309.
When the application 309 subsequently seeks to access a resource 327 using a network address (or, alternately, it initially attempts to directly access a resource 327 using a specific network address), it employs the process illustrated in
More particularly, if the VPN routing rules indicate that the client computer 301 can access the resource 327 at the requested network address, then the address filter 503 will provide the routing information to the IP router/routing table 315. If, however, the VPN routing rules indicate that the client computer 301 is not permitted to access the resource 327 at the requested network address, then the address filter 503 will not provide the routing information to the IP router/routing table 315. The address filter 503 then releases the request to the IP router/routing table 315. If the corresponding routing information was added to the IP router/routing table 315 (or was already in the IP router/routing table 315), then the application 309 will be given access to the requested resource. If the corresponding routing information was not added to the IP router/routing table 315, then the IP router/routing table 315 will must use existing routing rules to access resource 327 via a physical adapter 229 as if it were an external computer 235.
It should be noted that the network address for the remote resource 327 may conflict with an existing network address in the IP router/routing table 315 (e.g., the network address for a local resource.) Typically, the architecture of the IP router/routing table 315 will include precedence rules for handling conflicts. For example, the IP router/routing table 315 will usually access the most specific address first. If this policy does not resolve the conflict, then the IP router/routing table 315 will follow priority metrics associated with the conflicting addresses. Because various embodiments of the invention only provide routing information for specific host addresses to the IP router/routing table 315, the routing information provided by the address filter 503 will take precedence over conflicting network addresses that are already in the IP router/routing table 315. Still further, with some implementations of the invention, the address filter 503 with additionally assign the highest priority metric for the routing information it provides to the IP router/routing table 315.
With some embodiments of the invention, the address filter 503 maintains a look aside table 505 as noted above. The look aside table 505 maintains a copy of the VPN routing information previously provided to the IP router/routing table 315. This allows the address filter 503 to determine if VPN routing information already has been provided to the IP router/routing table 315 without having to query the IP router/routing table 315. Still further, the look aside table 505 may include time information (e.g., a time stamp) associated with the use of each VPN routing information entry. Using this time information, the address filter 503 can periodically purge VPN routing information from the IP router/routing table 315 that has not been used within a preset amount of time.
It also should be noted that, in some situations, a remote resource 327 may initiate communications to the application 309. This type of communication, commonly known as back connect or peer to peer access, is used for, e.g., Voice over IP (VoIP) telephony applications. When this type of communication occurs, the remote resource 327 will send a data packet to the application 309 through the virtual network adapter 313 and the IP router/routing table 315. The address filter 503 then will intercept the data packet, and examine the source information contained in the data packet. If the source information includes a network address for a resource 327 that is not already in the IP router/routing table 315, then the address filter 503 with compare the source network address with the VPN routing rules to determine if the new network address should be added to the IP router/routing table 315 using the same process already described for when application 309 initiates access to resource 327 with a network address.
Thus, as described above, the IP router/routing table 315 receives any necessary VPN routing information on a “just-in-time” basis. Using this “just-in-time” approach allows a local resource and a remote resource 327 to share the same network address. A conflict between the local resource and a remote resource 327 only occurs when the application 309 specifically seeks to access the remote resource 327 using its network address.
Termination and Resumption of the Virtual Private Network
In some situations, the client computer 301 may terminate the virtual private network connection between the virtual private network tool 311 and the remote network 311. For example, the user may move from a wired connection with a LAN to a wireless connection with a different LAN. Alternately, the virtual private network connection may drop simply because of a temporary electrical connection failure.
When the virtual private network adapter 313 determines that it can no longer communicate with the remote network 303, it notifies the virtual private network tool 311 of the termination of the virtual private network connection. The virtual private network tool 311 will then attempts to resume the virtual private network session. When the virtual private network tool 311 reestablishes the virtual private network connection (or establishes a new virtual private network connection after an intentional termination of a previous virtual private network connection), it will again complete the authentication process with the authentication server 317. Once the authentication server 317 has established the identity of the client computer 301, then the virtual private network tool 311 can simply provide the existing state information for the virtual private network adapter 313 to the address assignment server 319 for renewal.
More particularly, the virtual private network tool 311 can provide the address assignment server 319 with the network information previously used to provision the virtual private network adapter 313. If the previous network information does not conflict with the critical network information for the new virtual private network connection (e.g., a new IP address for the physical network adapter), then the address assignment server 319 can authorize the virtual private network adapter 313 to continue to use that previous network information (and, with some implementations of the invention, previously assigned VPN routing rules). Thus, with some embodiments of the invention, the virtual private network tool 311 can easily and quickly resume a terminated virtual private network. Moreover, the resumption can be made without having to again obtain the related VPN routing rules.
While the invention has been described with respect to specific examples including presently preferred modes of carrying out the invention, those skilled in the art will appreciate that there are numerous variations and permutations of the above described systems and techniques that fall within the spirit and scope of the invention as set forth in the appended claims. For example, while particular software services and processes have been described as performing various functions, it should be appreciated that the functionality of one or more of these services and processes may be combined into a single service or process, or divided among additional services and processes.
This application is a continuation and claims the priority benefit of U.S. patent application Ser. No. 13/038,340 filed Mar. 1, 2011, now U.S. Pat. No. 9,407,456 which is a divisional and claims the priority benefit of U.S. patent application Ser. No. 12/690,018 filed Jan. 19, 2010, now U.S. Pat. No. 8,090,827, which is a divisional and claims the priority benefit of U.S. patent application Ser. No. 11/927,250 filed Oct. 29, 2007 now U.S. Pat. No. 7,698,388, which is a continuation and claims the priority benefit of U.S. patent application Ser. No. 11/371,348 filed Mar. 7, 2006, now U.S. Pat. No. 8,661,158, which is a continuation-in-part and claims the priority benefit of U.S. patent application Ser. No. 11/251,592 filed Oct. 14, 2005, now U.S. Pat. No. 8,590,032, which claims the priority benefit of U.S. provisional application No. 60/619,151, filed Oct. 14, 2004; U.S. patent application Ser. No. 11/371,348 also claims the priority benefit of U.S. provisional application No. 60/659,494 filed Mar. 7, 2005, U.S. patent application Ser. No. 11/371,348 is also a continuation-in-part of and claims the priority benefit of U.S. patent application Ser. No. 11/009,692 filed Dec. 10, 2004, now U.S. Pat. No. 8,255,973, which claims the priority benefit of U.S. provisional application No. 60/528,870 filed Dec. 10, 2003, U.S. patent application Ser. No. 11/251,592 is a continuation-in-part and claims the priority benefit of U.S. patent application Ser. No. 11/009,692 filed Dec. 10, 2004, now U.S. Pat. No. 8,255,973 which claims the priority benefit of U.S. provisional application No. 60/528,870, filed Dec. 10, 2003. The disclosures of the aforementioned applications are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6052780 | Glover et al. | Apr 2000 | A |
6081601 | Raivisto | Jun 2000 | A |
6081900 | Subramaniam et al. | Jun 2000 | A |
6128279 | O'Neil et al. | Oct 2000 | A |
6138153 | Collins, III et al. | Oct 2000 | A |
6151631 | Ansell et al. | Nov 2000 | A |
6199099 | Gershman et al. | Mar 2001 | B1 |
6244758 | Solymar et al. | Jun 2001 | B1 |
6269392 | Cotichini et al. | Jul 2001 | B1 |
6300863 | Cotichini et al. | Oct 2001 | B1 |
6321334 | Jerger et al. | Nov 2001 | B1 |
6594704 | Birenback et al. | Jul 2003 | B1 |
6631416 | Bendinelli | Oct 2003 | B2 |
6675206 | Britton | Jan 2004 | B1 |
6691232 | Wood et al. | Feb 2004 | B1 |
6701437 | Hoke et al. | Mar 2004 | B1 |
6760330 | Tahan | Jul 2004 | B2 |
6772350 | Belani et al. | Aug 2004 | B1 |
6779030 | Dugan et al. | Aug 2004 | B1 |
6850943 | Texeira et al. | Feb 2005 | B2 |
6873988 | Herrmann et al. | Mar 2005 | B2 |
6874028 | Feinleib et al. | Mar 2005 | B1 |
6880005 | Bell et al. | Apr 2005 | B1 |
6920502 | Araujo et al. | Jul 2005 | B2 |
6957274 | Trace | Oct 2005 | B2 |
7000121 | Jarosz | Feb 2006 | B2 |
6996631 | Aiken, Jr. | Mar 2006 | B1 |
7017162 | Smith | Mar 2006 | B2 |
7073093 | Mannarsamy | Jul 2006 | B2 |
7088718 | Srivastava | Aug 2006 | B1 |
7092987 | Brittingham et al. | Aug 2006 | B2 |
7093024 | Craddock | Aug 2006 | B2 |
7099955 | Gregg | Aug 2006 | B1 |
7107614 | Boden et al. | Sep 2006 | B1 |
7124173 | Moriarty | Oct 2006 | B2 |
7127493 | Gautier | Oct 2006 | B1 |
7131141 | Blewett | Oct 2006 | B1 |
7222172 | Arakawa | May 2007 | B2 |
7272625 | Hannel et al. | Sep 2007 | B1 |
7283544 | Johnson et al. | Oct 2007 | B2 |
7289519 | Liskov | Oct 2007 | B1 |
7340483 | Gauthier | Mar 2008 | B1 |
7373660 | Guichard et al. | May 2008 | B1 |
7401354 | Boden et al. | Jul 2008 | B2 |
7447782 | Tahan | Nov 2008 | B2 |
7461147 | Mowat et al. | Dec 2008 | B1 |
7493380 | Aman et al. | Feb 2009 | B2 |
7574738 | Daude et al. | Aug 2009 | B2 |
7580919 | Hannel | Aug 2009 | B1 |
7624142 | Jungck | Nov 2009 | B2 |
7644151 | Jerrim et al. | Jan 2010 | B2 |
7698388 | Hoover | Apr 2010 | B2 |
7760701 | Levy-Abegnoli et al. | Jul 2010 | B2 |
7770222 | Hopen et al. | Aug 2010 | B2 |
7779469 | Hopen et al. | Aug 2010 | B2 |
7822829 | Philyaw et al. | Oct 2010 | B2 |
7822839 | Pruitt et al. | Oct 2010 | B1 |
7827590 | Hopen et al. | Nov 2010 | B2 |
7865603 | Braddy et al. | Jan 2011 | B2 |
7870294 | Braddy et al. | Jan 2011 | B2 |
8005983 | Hopen et al. | Aug 2011 | B2 |
8090827 | Hoover et al. | Jan 2012 | B2 |
8205259 | Stute | Jun 2012 | B2 |
8255973 | Hopen et al. | Aug 2012 | B2 |
8301769 | Hopen et al. | Oct 2012 | B2 |
8499344 | Read | Jul 2013 | B2 |
8510474 | Van Aken et al. | Aug 2013 | B2 |
8590032 | Hopen | Nov 2013 | B2 |
8601550 | Hopen | Dec 2013 | B2 |
8613041 | Hopen | Dec 2013 | B2 |
8615796 | Hopen | Dec 2013 | B2 |
8661158 | Hoover | Feb 2014 | B2 |
9197538 | Hopen | Nov 2015 | B2 |
9300670 | Hopen | Mar 2016 | B2 |
9397927 | Hopen | Jul 2016 | B2 |
9407456 | Hoover | Aug 2016 | B2 |
9628489 | Hoover | Apr 2017 | B2 |
9906534 | Hopen | Feb 2018 | B2 |
20010052007 | Shigezumi | Dec 2001 | A1 |
20020026576 | Das-Purkayastha et al. | Feb 2002 | A1 |
20020053031 | Bendinelli et al. | May 2002 | A1 |
20020065938 | Jungck et al. | May 2002 | A1 |
20020078215 | Tahan | Jun 2002 | A1 |
20020099937 | Tuomenoksa | Jul 2002 | A1 |
20020103903 | Bruton et al. | Aug 2002 | A1 |
20020112052 | Brittingham et al. | Aug 2002 | A1 |
20020143946 | Crosson | Oct 2002 | A1 |
20020161755 | Moriarty | Oct 2002 | A1 |
20020167965 | Beasley et al. | Nov 2002 | A1 |
20020198984 | Goldstein et al. | Dec 2002 | A1 |
20030051042 | Tazoe | Mar 2003 | A1 |
20030055990 | Cheline et al. | Mar 2003 | A1 |
20030070096 | Pazi et al. | Apr 2003 | A1 |
20030074472 | Lucco et al. | Apr 2003 | A1 |
20030149766 | Syvanne et al. | Aug 2003 | A1 |
20030154306 | Perry | Aug 2003 | A1 |
20030191944 | Rothrock | Oct 2003 | A1 |
20030196091 | Raley et al. | Oct 2003 | A1 |
20030196121 | Raley et al. | Oct 2003 | A1 |
20030210791 | Binder | Nov 2003 | A1 |
20030229613 | Zargham et al. | Dec 2003 | A1 |
20030233401 | Dean | Dec 2003 | A1 |
20040003084 | Malik | Jan 2004 | A1 |
20040015725 | Boneh et al. | Jan 2004 | A1 |
20040015961 | Chefalas et al. | Jan 2004 | A1 |
20040042605 | Evslin | Mar 2004 | A1 |
20040078384 | Keir et al. | Apr 2004 | A1 |
20040078471 | Yang | Apr 2004 | A1 |
20040148439 | Harvey et al. | Jul 2004 | A1 |
20040153533 | Lewis | Aug 2004 | A1 |
20040165592 | Chen et al. | Aug 2004 | A1 |
20040215823 | Kleinfelter et al. | Oct 2004 | A1 |
20040223491 | Levy-Abegnoli et al. | Nov 2004 | A1 |
20040249919 | Mattheis | Dec 2004 | A1 |
20050027784 | Fusari | Feb 2005 | A1 |
20050044544 | Slivka et al. | Feb 2005 | A1 |
20050053063 | Madhavan | Mar 2005 | A1 |
20050076139 | Jinmei et al. | Apr 2005 | A1 |
20050076141 | Williams et al. | Apr 2005 | A1 |
20050083955 | Guichard et al. | Apr 2005 | A1 |
20050120095 | Aman et al. | Jun 2005 | A1 |
20050144286 | Szu et al. | Jun 2005 | A1 |
20050144481 | Hopen et al. | Jun 2005 | A1 |
20050273779 | Cheng et al. | Dec 2005 | A1 |
20060143703 | Hopen et al. | Jun 2006 | A1 |
20060161970 | Hopen et al. | Jul 2006 | A1 |
20060162726 | Smith et al. | Jul 2006 | A1 |
20060271544 | Devarakonda et al. | Nov 2006 | A1 |
20070061887 | Hoover et al. | Mar 2007 | A1 |
20080134302 | Hopen et al. | Jun 2008 | A1 |
20080148364 | Hopen et al. | Jun 2008 | A1 |
20080162698 | Hopen et al. | Jul 2008 | A1 |
20080162726 | Hoover et al. | Jul 2008 | A1 |
20100024008 | Hopen et al. | Jan 2010 | A1 |
20100036955 | Hopen et al. | Feb 2010 | A1 |
20100121943 | Hoover et al. | May 2010 | A1 |
20100333169 | Hopen et al. | Dec 2010 | A1 |
20110167101 | Hopen et al. | Jul 2011 | A1 |
20110167475 | Hoover et al. | Jul 2011 | A1 |
20140053237 | Hopen | Feb 2014 | A1 |
20140123225 | Hopen | May 2014 | A1 |
20150052248 | Hopen | Feb 2015 | A1 |
20160212136 | Hopen | Jul 2016 | A1 |
20160294778 | Hopen | Oct 2016 | A1 |
Number | Date | Country |
---|---|---|
0804012 | Oct 1997 | EP |
1308822 | May 2003 | EP |
2 264 951 | Dec 2010 | EP |
2004-064182 | Feb 2004 | JP |
2005-210380 | Aug 2005 | JP |
2006-013732 | Jan 2006 | JP |
WO 99057866 | Nov 1999 | WO |
WO 2002037799 | May 2002 | WO |
WO 02099571 | Dec 2002 | WO |
WO 2006044820 | Apr 2006 | WO |
Entry |
---|
U.S. Appl. No. 15/180,329, filed Jun. 13, 2016, Chris Hopen, Rule-Based Routing to Resources Through a Network. |
“Microsoft® Computer Dictionary,” Fifth Edition, Microsoft Press, May 1, 2002, 2 pages. |
Canter, Sheryl “Kill Internet Ads with HOSTS and PAC Files,” Online! Mar. 30, 2004, retrieved from the internet URL: http://web.archive.org/web20040426140542/http://www.windowsdevcenter.com/pub/a/windows/2004/03/30/hosts.html, retrieved Jan. 24, 2006. |
Cisco et al., “Release Notes for Cisco Cache Engine, Version 2.0.3,” Dec. 1999, pp. 1-11. |
Kritzner, Ulrich “Objektrferenz-Das Navigator-Objekt,” Javascript-Tutorial, Online!, Mar. 31, 2002, XP 002331683 retrieved from http://web/archive.org/web/2002033104028/http://js-tut.aardon.de/js-tut/anhangA/navigator.html. |
Napier, Duncan “Setting up a VPN Gateway,” Linux Journal, vol. 2002, Issue 93, Specialized Systems Consultants, Inc., Jan. 2002, 11 pages. |
NN9603183. “Security for Routing Based on Link State Algorithms.” IBM Technical Disclosure Bulletin. Mar. 1996. US. vol. 39, Issue 3, pp. 183-190. |
Papadimitratos, Panagiotis et al. “Securing the Internet Routing Infrastructure.” IEEE Communications Magazine. Oct. 2002. IEEE Press. 60-68. |
Ragunath, Satish et al., “Measurement Based Characterization and Provisioning of IP VPNs,” Proceedings of the 4th ACM SIGCOMM Conference on Internet Measurement, ACM Press, Oct. 2004, 342-55. |
International Search Report and Written Opinion for PCT/US2005/037292 dated Apr. 7, 2006. |
U.S. Appl. No. 11/009,692 Final Office Action dated Dec. 2, 2008. |
U.S. Appl. No. 11/009,692 Office Action dated Aug. 29, 2008. |
U.S. Appl. No. 12/821,060 Final Office Action dated Mar. 12, 2012. |
U.S. Appl. No. 12/821,060 Office Action dated Oct. 27, 2011. |
U.S. Appl. No. 11/927,310 Office Action dated Feb. 5, 2010. |
U.S. Appl. No. 11/251,592 Final Office Action dated Dec. 6, 2011. |
U.S. Appl. No. 11/251,592 Office Action dated Apr. 13, 2011. |
U.S. Appl. No. 11/251,592 Final Office Action dated Nov. 9, 2010. |
U.S. Appl. No. 11/251,592 Office Action dated Jul. 20, 2010. |
U.S. Appl. No. 11/251,592 Final Office Action dated Nov. 3, 2009. |
U.S. Appl. No. 11/251,592 Office Action dated Apr. 29, 2009. |
U.S. Appl. No. 11/972,272 Final Office Action dated May 12, 2010. |
U.S. Appl. No. 11/972,272 Office Action dated Sep. 29, 2009. |
U.S. Appl. No. 14/061,988 Office Action dated Nov. 26, 2014. |
U.S. Appl. No. 15/180,329 Office Action dated Aug. 8, 2016. |
U.S. Appl. No. 12/512,884 Final Office Action dated Aug. 3, 2011. |
U.S. Appl. No. 12/512,884 Office Action dated Jan. 19, 2011. |
U.S. Appl. No. 12/512,891 Final Office Action dated Aug. 18, 2011. |
U.S. Appl. No. 12/512,891 Office Action dated Mar. 1, 2011. |
U.S. Appl. No. 14/477,767 Final Office Action dated Oct. 26, 2015. |
U.S. Appl. No. 14/477,767 Office Action dated Mar. 17, 2015. |
U.S. Appl. No. 11/371,348 Final Office Action dated Feb. 22, 2013. |
U.S. Appl. No. 11/371,348 Office Action dated Sep. 21, 2012. |
U.S. Appl. No. 11/371,348 Final Office Action dated Jun. 6, 2011. |
U.S. Appl. No. 11/371,348 Office Action dated Nov. 30, 2010. |
U.S. Appl. No. 11/371,348 Final Office Action dated Mar. 24, 2010. |
U.S. Appl. No. 11/371,348 Office Action dated Sep. 25, 2009. |
U.S. Appl. No. 12/690,018 Office Action dated Feb. 9, 2011. |
U.S. Appl. No. 13/038,340 Final Office Action dated Feb. 2, 2016. |
U.S. Appl. No. 13/038,340 Office Action dated Jun. 2, 2015. |
U.S. Appl. No. 13/038,340 Final Office Action dated Dec. 17, 2013. |
U.S. Appl. No. 13/038,340 Office Action dated Sep. 6, 2013. |
U.S. Appl. No. 13/038,340 Final Office Action dated Jul. 25, 2013. |
U.S. Appl. No. 13/038,340 Office Action dated Mar. 14, 2013. |
U.S. Appl. No. 13/038,340 Office Action dated Dec. 5, 2012. |
U.S. Appl. No. 11/251,087 Office Action dated Jul. 20, 2010. |
U.S. Appl. No. 11/251,087 Final Office Action dated Mar. 3, 2010. |
U.S. Appl. No. 11/251,087 Office Action dated Aug. 20, 2009. |
U.S. Appl. No. 11/927,286 Office Action dated Nov. 17, 2009. |
U.S. Appl. No. 12/938,330 Final Office Action dated Feb. 1, 2013. |
U.S. Appl. No. 12/938,330 Office Action dated Jun. 27, 2011. |
U.S. Appl. No. 14/058,215 Final Office Action dated Aug. 26, 2015. |
U.S. Appl. No. 14/058,215 Office Action dated Feb. 5, 2015. |
U.S. Appl. No. 15/082,485 Office Action dated Jul. 18, 2016. |
U.S. Appl. No. 15/180,329 Office Action dated Jun. 16, 2017. |
U.S. Appl. No. 15/476,547 Office Action dated Jul. 12, 2017. |
U.S. Appl. No. 15/180,329 Final Office Action dated Dec. 9, 2016. |
U.S. Appl. No. 15/907,194, filed Feb. 27, 2018, Chris Hopen, Remote Access to Resources Over a Network. |
U.S. Appl. No. 15/476,547, Chris Hopen, Remote Access to Resources Over a Network. |
Number | Date | Country | |
---|---|---|---|
20160323286 A1 | Nov 2016 | US |
Number | Date | Country | |
---|---|---|---|
60619151 | Oct 2004 | US | |
60659494 | Mar 2005 | US | |
60528870 | Dec 2003 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12690018 | Jan 2010 | US |
Child | 13038340 | US | |
Parent | 11927250 | Oct 2007 | US |
Child | 12690018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13038340 | Mar 2011 | US |
Child | 15208197 | US | |
Parent | 11371348 | Mar 2006 | US |
Child | 11927250 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11251592 | Oct 2005 | US |
Child | 11371348 | US | |
Parent | 11009692 | Dec 2004 | US |
Child | 11251592 | US | |
Parent | 11009692 | Dec 2004 | US |
Child | 11251592 | Oct 2005 | US |