The present disclosure relates to computerized systems and methods for assigning a network address to an unknown client device, and more generally, to network access technologies. By way of example, and without limitation, the present disclosure relates to computerized systems and methods for receiving a request for a network address, and for assigning the network address to an unknown client device in response to the request.
The use of electronic devices to access content over networks has grown significantly over the years. People can now interact with content over networks using a variety of electronic devices. Moreover, people take their electronic devices with them, and access content using different networks at different locations. As a result, electronic devices are often connecting or disconnecting from networks based on changes in location, power state, usage, and more. It is therefore important that networks, such as packet-switched networks, appropriately distribute network configuration parameters, such as network addresses, to electronic devices.
Dynamic Host Configuration Protocol (DHCP) is a network protocol used on Internet Protocol (IP) networks for dynamically distributing network configuration parameters, such as IP addresses, to electronic devices. DHCP allows electronic devices to automatically request network parameters and IP addresses from a DHCP server, and allows the DHCP server to automatically assign the parameters and addresses, thus reducing the need for manual network configuration.
DHCP servers may allocate IP addresses in three different ways. A first method of allocating IP addresses may include dynamic allocation. With dynamic allocation, a network administrator may reserve a range of IP addresses for DHCP. Electronic devices may request IP addresses from the DHCP server, and the DHCP server may allocate and reclaim IP addresses as electronic devices connect and disconnect from the network. A second method of allocating IP addresses may include automatic allocation. With automatic allocation, a DHCP server may permanently assign an IP address to a requesting electronic device from a range of IP addresses defined by a network administrator. The DHCP server may maintain a table of past IP address assignments, so that it may continue to assign the same IP address to an electronic device. A third method of allocating IP addresses may include static allocation. With static allocation, a DHCP server may allocate an IP address based on a preconfigured mapping to an electronic device.
DHCP servers may service networks of varying scales. In small networks, a DHCP server may only need to service a few electronic devices. Large networks, by contrast, may include many network links, and may rely on DHCP relay agents to relay messages between hundreds, or even thousands, of electronic devices and a DHCP server. A number of messages have to be sent between an electronic device and a DHCP server in order for the electronic device to receive an IP address. Unfortunately, DHCP servers can lose information about electronic devices that have been assigned IP addresses, such as when a DHCP server fails. These electronic devices may have to request IP addresses all over again, which can create a heavy workload for the DHCP server, and long delays in receiving IP addresses for the electronic devices.
Embodiments of the present disclosure relate to computerized systems and methods for assigning a network address to an unknown client device. In addition, embodiments of the present disclosure relate to receiving a request for a network address, and for assigning the network address to an unknown client device in response to the request.
In accordance with certain embodiments of the present disclosure, computerized systems and methods are provided that receive a message requesting assignment of a network address to a client device, and determine that identification information for the client device is not stored in a storage device. Once the determination has been made, the computerized systems and methods may cause a request for authentication of the client device to be sent to a server. The computerized systems and methods may then receive an indication that the server authenticated the client device in response to the request, and may assign the network address to the client device in response to the indication.
In accordance with some embodiments, there is provided a computer-implemented method for assigning an IP address to a client device through an authentication process without needing to receive a DHCP discover message to trigger the authentication process. The method comprises receiving a DHCP request message requesting assignment of an IP address to the client device, and determining, by one or more processors in response to the DHCP request message, that identification information for the client device is not stored in a storage device. The method also comprises causing a request for authentication of the client device to be sent to a server in response to the determination. The method further comprises receiving an indication that the server authenticated the client device in response to the request, and assigning the IP address to the client device in response to the indication, whereby the IP address is assigned to the client device through the authentication process without needing to receive a DHCP discover message to trigger the authentication process.
Furthermore, in accordance with some embodiments, there is provided a computer-implemented system for assigning an IP address to a client device through an authentication process without needing to receive a DHCP discover message to trigger the authentication process. The system comprises one or more memory devices that store instructions, and one or more processors. The one or more processors execute the instructions to receive a DHCP request message requesting assignment of an IP address to the client device, and determine, in response to the DHCP request message, that identification information for the client device is not stored in a storage device. The one or more processors also execute the instructions to cause a request for authentication of the client device to be sent to a server in response to the determination. The one or more processors further execute the instructions to receive an indication that the server authenticated the client device in response to the request, and to assign the IP address to the client device in response to the indication, whereby the IP address is assigned to the client device through the authentication process without needing to receive a DHCP discover message to trigger the authentication process.
Additionally, in accordance with some embodiments, there is provided a non-transitory computer-readable medium that stores instructions. The instructions, when executed by one or more processors, cause the one or more processors to perform a method for assigning an IP address to a client device through an authentication process without needing to receive a DHCP discover message to trigger the authentication process. The method comprises receiving a DHCP request message requesting assignment of an IP address to the client device, and determining, in response to the DHCP request message, that identification information for the client device is not stored in a storage device. The method also comprises causing a request for authentication of the client device to be sent to a server in response to the determination. The method further comprises receiving an indication that the server authenticated the client device in response to the request, and assigning the IP address to the client device in response to the indication, whereby the IP address is assigned to the client device through the authentication process without needing to receive a DHCP discover message to trigger the authentication process.
Before explaining example embodiments consistent with the present disclosure in detail, it is to be understood that the disclosure is not limited in its application to the details of constructions and to the arrangements set forth in the following description or illustrated in the drawings. The disclosure is capable of embodiments in addition to those described and is capable of being practiced and carried out in various ways. Also, it is to be understood that the phraseology and terminology employed herein, as well as in the abstract, are for the purpose of description and should not be regarded as limiting.
It is to be understood that both the foregoing general description and the following detailed description are explanatory only and are not restrictive of the claimed subject matter.
The accompanying drawings, which are incorporated in and constitute part of this specification, and together with the description, illustrate and serve to explain the principles of various example embodiments.
In the following description, numerous specific details are set forth regarding the systems and methods of the disclosed subject matter and the environment in which such systems and methods may operate, etc., in order to provide a thorough understanding of the disclosed subject matter. It will be apparent to one skilled in the art, however, that the disclosed subject matter may be practiced without such specific details, and that certain features, which are well known in the art, are not described in detail in order to avoid unnecessary complication of the disclosed subject matter. In addition, it will be understood that the embodiments provided below are exemplary, and that it is contemplated that there are other systems and methods that are within the scope of the disclosed subject matter.
Embodiments of the present disclosure relate to computerized systems and methods for assigning a network address to an unknown client device. Embodiments of the present disclosure include systems and methods that may receive a request for a network address, and that may assign the network address to an unknown client device in response to the request. For example, a message may be received that includes a request for assignment of a network address to a client device. Based on the message, it may be determined that identification information for the client device is not stored in a storage device. For example, the storage device may store identification information for client devices that are authorized to receive network addresses, or which have previously been assigned network addresses. If a message is received from a client device for which identification information is not stored, a request for authentication of the client device may be sent to a server. The server may contain information about whether the client device is authorized to receive a network address. If the server determines that the client device is authorized to receive a network address, an indication may be received that the server has authenticated the client device. Based on this indication the requested network address may be assigned to the client device.
One or more advantages may be achieved by assigning network addresses, such as IP addresses, dynamically, such as with DHCP. For example, dynamic assignment of network addresses can reduce the need for a network administrator or user to configure the network addresses manually. This can allow a server, such as a DHCP server, to automatically manage assignment of network addresses on very large networks. However, when a gateway loses information about a client device, such as the client device 102 in
As can be seen in
Embodiments of the present disclosure can address the limitations associated with DHCP network address assignment. For example, embodiments of the present disclosure provide computerized systems and methods that may receive a message, such as a DHCP request message, requesting assignment (e.g., a lease renewal) of a network address to a client device. In response to the message, a storage device can be checked for information identifying the client device. If identification information for the client device is not stored in the storage device (e.g., the information has been lost), rather than sending a DHCP NAK message to the client device, a request for authentication of the client device may be sent to a server (e.g., an AAA server). The server may then check to see if it can determine if the client device is authorized. The server may then send a response indicating whether the client device is authorized. If the response indicates that the client device is authorized, the network address may be assigned to the client device.
As shown in
By way of example, a client device 310 could be a personal computer, desktop computer, laptop computer, server, mobile computer, mobile phone, smart phone, tablet computer, netbook, electronic reader, personal digital assistant (PDA), wearable computer, smart watch, gaming device, set-top box, television, personal organizer, portable electronic device, smart appliance, navigation device, and/or other type of computing device. In some embodiments, a client device 310 may be implemented with hardware devices and/or software applications running thereon. A client device 310 may communicate with one or more computer systems (e.g., access point device(s) 330, gateway(s) 350, server(s) 370) over one or more networks 320, 340, 360. A client device 310 may store browser software that enables client device 310 to access resources on a network, such as the Internet, and DHCP client software that enables client device 310 to receive an IP address over DHCP protocol. In some embodiments, one or more of client device(s) 310 may be implemented using a computer system, such as computer system 600 of
Computing environment 300 may include one or more networks 320. In one embodiment, network(s) 320 may be one or more local networks (e.g., personal area networks (PANs), local area networks (LANs), metropolitan area networks (MANs)), though the disclosure is not so limited. Network(s) 320 may connect client device(s) 310 with one or more access point devices 330, gateways 350, servers 370, and/or other client devices 310. Network(s) 320 may include one or more PANs, LANs, MANs, wide area networks (WANs), or any combination of these networks. Network(s) 320 may include a combination of a variety of different network types, including Ethernet, intranet, twisted-pair, coaxial cable, fiber optic, cellular, satellite, IEEE 802.11, WiFi, terrestrial, Internet, and/or other types of wired or wireless networks.
Client device(s) 310, gateway(s) 350, and/or server(s) 370 may be configured to communicate with one or more access point devices 330 through one or more networks 320. An access point device 330 may be a router or other type of device that may relay messages onto different networks, or different links of a network. In some embodiments, an access point device 330 may control incoming and outgoing network traffic based on pre-established rules. In some embodiments, an access point device may append information, such as data identifying a location or subnet of a network on which the access point device is located, before relaying the message to other network devices. An access point device 330 may by any type of device for relaying network messages, and may exist as software, hardware, or a combination of software and hardware. In some embodiments, one or more access point devices 330 may be implemented using a computer system, such as computer system 600 of
Computing environment 300 may also include one or more networks 340. In one embodiment, network(s) 340 may be one or more local networks (e.g., personal area networks (PANs), local area networks (LANs), metropolitan area networks (MANs)), though the disclosure is not so limited. Network(s) 340 may connect gateway(s) 350 and/or access point device(s) 330 with one or more client devices 310, servers 370, other access point devices 330, and/or other gateways 350. Network(s) 340 may include one or more PANs, LANs, MANs, wide area networks (WANs), or any combination of these networks. Network(s) 340 may include a combination of a variety of different network types, including Ethernet, intranet, twisted-pair, coaxial cable, fiber optic, cellular, satellite, IEEE 802.11, WiFi, terrestrial, Internet, and/or other types of wired or wireless networks.
Client device(s) 310, access point device(s) 330, and/or server(s) 370 may be configured to communicate with one or more gateways 350 through one or more networks 320, 340, 360. A gateway 350 may control incoming and outgoing network traffic based on pre-established rules, convert messages between different network protocols, store information about client devices 310 on a network, and/or store information about network configuration parameters. In some embodiments, a gateway 350 may be a DHCP server or may include a DHCP server, and may include one or more storage devices (e.g., storage medium(s) 650 of
A gateway 350 may be implemented as a server system comprising a plurality of servers, or a server farm comprising a load balancing system and a plurality of servers. A gateway 350 may be any type of known gateway, such as a wireless access gateway (WAG) or WiFi gateway, and may include any type of known DHCP server. A gateway 350 may exist as software, hardware, or a combination of software and hardware. In some embodiments, one or more gateways 350 may be implemented using a computer system, such as computer system 600 of
Computing environment 300 may also include one or more networks 360. In one embodiment, network(s) 360 may be one or more local networks (e.g., personal area networks (PANs), local area networks (LANs), metropolitan area networks (MANs)), though the disclosure is not so limited. Network(s) 360 may connect server(s) 370 with one or more client devices gateways 350, access point devices 330, client devices 310, and/or other servers 370. Network(s) 360 may include one or more PANs, LANs, MANs, wide area networks (WANs), or any combination of these networks. Network(s) 360 may include a combination of a variety of different network types, including Ethernet, intranet, twisted-pair, coaxial cable, fiber optic, cellular, satellite, IEEE 802.11, WiFi, terrestrial, Internet, and/or other types of wired or wireless networks.
Client device(s) 310, access point device(s) 330, and/or gateway(s) 350 may be configured to communicate with one or more servers 370. A server 370 may be a network solution for controlling incoming and outgoing network traffic based on pre-established rules, and may store policies provisioned by a network administrator to accept or deny certain devices onto a network. In some embodiments, a server 370 may be an authentication, authorization, and accounting (AAA) server, such as a Remote Authentication Dial In User Service (RADIUS) server or a Terminal Access Controller Access-Control System (TACACS) server. A server 370 may store rules for authenticating client devices 310 onto a network, and/or may store information identifying client devices 310 (e.g., MAC addresses, device names, user names, domain names, device addresses). A server 370 may be a standalone computer system or apparatus, or it may be part of a larger system. For example, server(s) 370 may represent distributed servers that are remotely located and communicate over a communications network, such as a LAN. Server(s) 370 may include one or more back-end servers for carrying out one or more aspects of the present disclosure.
A server 370 may be implemented as a server system comprising a plurality of servers, or a server farm comprising a load balancing system and a plurality of servers. A server 370 may be any type of known server, and may exist as software, hardware, or a combination of software and hardware. In some embodiments, one or more server(s) 370 may be implemented using a computer system, such as computer system 600 of
Although computing environment 300 of
Although computing environment 300 of
In step 410, a message requesting assignment of a network address to a client device, such as a client device 310, may be received. The message may be, for example, a DHCP request message. The message may be received directly from a client device 310 over network(s) 320, or may be received from an access point device 330 that relayed a DHCP message from a client device 310. The message may specify a particular IP address that the client device is requesting. For example, the IP address may have already been assigned to the client device, and the message may request renewal of a lease on the IP address. As another example, the IP address may be an IP address that was recently associated with the client device. As still another example, the IP address may be an address that was associated with the client device at some point prior to receiving the request, or which the client device desires for some particular reason. The message may also include information identifying the client device, such as a MAC address of the client device, a subnet to which the client device is connected, a hardware address of the client device, a device address of the client device, a user name associated with the client device, a domain name associated with the client device, and/or any other information that identifies the client device. Once the message has been received, method 400 may proceed to step 420.
In step 420, a storage device may be checked to determine whether information identifying the client device is stored. For example, a storage device (e.g., a storage medium 650 of
In step 430, method 400 may cause a request for authentication to be sent. For example, in response to the determination that information identifying the client device is not stored in the storage device in step 420, method 400 may cause a request for authentication to be sent to a server 370. The request for authentication may be sent, for example, to an AAA server, such as a RADIUS server, and may include a RADIUS access request. The request may be a message including information that was extracted from the message received in step 410, such as information identifying the client device. When the request for authentication is sent, the request for assignment of the network address (e.g., the DHCP request message) received in step 410 may be cached. The server may receive the request, and compare the information in the request with information stored in the server to determine whether the client device is authorized for assignment of the IP address. The server may then send a message responding to the authentication request indicating whether the client device is authorized. The response message may include, for example, a RADIUS access response message. Once the response message has been received, method 400 may proceed to step 440.
In step 440, the response message may be received. If the response message indicates that the client device is not authorized for assignment of the IP address, a NAK message may be sent to the client device indicating that the client device has not been assigned the IP address. If the response message indicates that the client device is authorized for assignment of the IP address, method 400 may proceed to step 450.
In step 450, the IP address may be assigned to the client device. In some embodiments, the IP address may only be assigned to the client device if the requested IP address is available, and/or if the requested IP address is on one of the subnets configured for dynamic allocation. In some embodiments, method 400 may store information indicating that the IP address has been assigned to the client device in the storage device in step 450. Once the IP address has been assigned to the client device, a message, such as a DHCP ACK message, may be sent to the client device confirming that the client device has been assigned the IP address. The message may also include a lease period indicating a time period during which the IP address will be assigned to the client device. Once the client device receives the confirmation message, the client device may begin using the IP address.
The above description of method 400 describes that the method may determine whether the requested IP address is available in step 450. However, the disclosure is not so limited. Method 400 may, for example, determine whether the requested IP address is available in any of steps 410, 420, 430, or 440. If it is determined that the requested IP address is not available in step 410, for example, a NAK message could be sent to the client device, and method 400 would not have to proceed through steps 420, 430, 440, and/or 450. Similarly, the above description of method 400 describes determining whether the requested IP address is on one of the subnets configured for dynamic allocation in step 450. However, method 400 may determine whether the requested IP address is on one of the subnets configured for dynamic allocation in any of steps 410, 420, 430, or 440. If it is determined that the requested IP address is not on one of the subnets configured for dynamic allocation in step 410, for example, a NAK message could be sent to the client device, and method 400 would not have to proceed through steps 420, 430, 440, and/or 450.
In embodiments where the DHCP server is a separate process included in gateway 350, or is a separate server connected to gateway 350 over a network (e.g., one of networks 320, 340, 360), method 400 may include caching DHCP protocol messages and forwarding them to the DHCP server only after a certain step of method 400 has been satisfied. For example, in step 410, the message requesting assignment of an IP address may be a DHCP request message. A gateway receiving this message may cache the message until the gateway has received a message (e.g, from a RADIUS server) indicating that the client device is authenticated. Once RADIUS authentication has succeeded, the gateway may forward the DHCP request message to the DHCP server, so that the IP address may be assigned to the client device. In doing so, the gateway may move the client device to a DHCP REQUEST state in the DHCP server. In some embodiments, the DHCP server may check whether the IP address requested by the client device is available for assignment and/or whether the IP address requested by the client device is on a subnet configured for dynamic IP address allocation prior to assigning the IP address to the client device. Once the IP address has been assigned to the client device, the gateway may receive a DHCP ACK message from the DHCP server, and may forward the DHCP ACK message to the client device.
A gateway 350 performing method 400 may include an ability to handle certain error cases that may arise in performing the method. For example, a DHCP request message may be received by the gateway from a client device when a DHCP request message from the client device is already cached at the gateway awaiting RADIUS authentication. In such a scenario, the gateway may replace the cached DHCP request message with the DHCP request message that was more recently received by the gateway, and may keep a DHCP state for the client device at the DHCP server at a REQUEST state. As another example, a DHCP discover message may be received by the gateway from a client device when a DHCP discover message from the client device is already cached at the gateway awaiting a RADIUS authentication. In such a scenario, the gateway may replace the cached DHCP discover message with the DHCP discover message that was more recently received by the gateway, and may move a DHCP state for the client device at the DHCP server to a DISCOVER state. As still another example, if an IP address requested in a DHCP request message does not match a subnet configured for dynamic IP address allocation, or is not available for assignment, the DHCP server can send a DHCP NAK message to the gateway, and a DHCP state for the client device at the DHCP server can be moved to a NONE state. As a further example, if a DHCP request message is received when a DHCP state in a DHCP server is at a NONE state, the state can be moved to a REQUEST state.
A gateway 350 performing method 400 may also include registration timeout periods to delete information identifying client devices from a cache or storage device. A time period for the registration timeout may be preset (e.g., five minutes) or configurable by a network administrator. In some embodiments, a timer may be started in the gateway when a DHCP NAK message has been sent by the gateway to the client device. The timer may be cancelled if any DHCP protocol message is received by the gateway for the client device. If no DHCP protocol message is received by the gateway for the client device before the time of the timer equals the registration timeout time period, the information identifying the client device may be deleted from a cache or storage device at the gateway.
Although
As can seen from
As shown in
A computing device 610 may include one or more storage devices configured to store data and/or software instructions used by processor(s) 620 to perform operations consistent with disclosed embodiments. For example, a computing device 610 may include main memory 640 configured to store one or more software programs that, when executed by processor(s) 620, cause processor(s) 620 to perform functions or operations consistent with disclosed embodiments.
By way of example, main memory 640 may include NOR and/or NAND flash memory devices, read only memory (ROM) devices, random access memory (RAM) devices, etc. A computing device 610 may also include one or more storage mediums 650. By way of example, storage medium(s) 650 may include hard drives, solid state drives, tape drives, redundant array of independent disks (RAID) arrays, etc. Although
Storage medium(s) 650 may be configured to store data, and may store data received from one or more of client device(s) 310, access point device(s) 330, gateway(s) 350, and/or server(s) 370. The data may take or represent various content or information forms, such as documents, tables, lists, IP addresses, client device information, security information, software applications, files, and any other type of information and/or content which may be used in network applications, or any combination thereof.
A computing device 610 may further include one or more communication interfaces 660. Communication interface(s) 660 may allow software and/or data to be transferred between client device(s) 310, access point device(s) 330, gateway(s) 350, and server(s) 370. Examples of communications interface 660 may include a modem, network interface card (e.g., Ethernet card), communications port, personal computer memory card international association (PCMCIA) slots and cards, antennas, etc. Communications interface(s) 660 may transfer software and/or data in the form of signals, which may be electronic, electromagnetic, optical, and/or other types of signals. The signals may be provided to/from communication interface(s) 660 via a communications path (e.g., network(s) 320, 340, 360), which may be implemented using wired, wireless, cable, fiber optic, radio frequency (RF), and/or other communications channels.
The disclosed embodiments are not limited to separate programs or computers configured to perform dedicated tasks. For example, a gateway 350 may include a computing device 610 that includes a main memory 640 that stores a single program or multiple programs and may additionally execute one or more programs located remotely from gateway 350. Similarly, a client device 310, access point device 330, and/or server 370 may execute one or more remotely stored programs instead of, or in addition to, programs stored on these devices. In some examples, a gateway 350 may be capable of accessing separate server(s), gateways, DHCP servers, and/or computing devices that generate, maintain, and provide network configuration information and/or client device information.
Although the description above has described the use of gateway(s) 350 in the context of assigning IP addresses to client devices, the disclosure is not so limited. One of skill in the art would recognize that a gateway 350 implementing the features and embodiments of the present disclosure may assign other types of network addresses based on requests from client devices, in a similar manner to that disclosed herein. That is, the features and embodiments disclosed herein are not limited in application to assigning IP addresses.
The subject matter described herein can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structural means disclosed in this specification and structural equivalents thereof, or in combinations of them. The subject matter described herein can be implemented as one or more computer program products, such as one or more computer programs tangibly embodied in an information carrier (e.g., in a machine readable storage device), or embodied in a propagated signal, for execution by, or to control the operation of, data processing apparatus (e.g., a programmable processor, a computer, or multiple computers). A computer program (also known as a program, software, software application, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file. A program can be stored in a portion of a file that holds other programs or data, in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification, including the method steps of the subject matter described herein, can be performed by one or more programmable processors executing one or more computer programs to perform functions of the subject matter described herein by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus of the subject matter described herein can be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processor of any kind of digital computer. Generally, a processor will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. Information carriers suitable for embodying computer program instructions and data include all forms of nonvolatile memory, including by way of example semiconductor memory devices, (e.g., EPROM, EEPROM, and flash memory devices); magnetic disks, (e.g., internal hard disks or removable disks); magneto optical disks; and optical disks (e.g., CD and DVD disks). The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, the subject matter described herein can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, (e.g., a mouse or a trackball), by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well. For example, feedback provided to the user can be any form of sensory feedback, (e.g., visual feedback, auditory feedback, or tactile feedback), and input from the user can be received in any form, including acoustic, speech, or tactile input.
The subject matter described herein can be implemented in a computing system that includes a back end component (e.g., a data server), a middleware component (e.g., an application server), or a front end component (e.g., a client computer having a graphical user interface or a web browser through which a user can interact with an implementation of the subject matter described herein), or any combination of such back end, middleware, and front end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
It is to be understood that the disclosed subject matter is not limited in its application to the details of construction and to the arrangements of the components set forth in the following description or illustrated in the drawings. The disclosed subject matter is capable of other embodiments and of being practiced and carried out in various ways. Also, it is to be understood that the phraseology and terminology employed herein are for the purpose of description and should not be regarded as limiting.
As such, those skilled in the art will appreciate that the conception, upon which this disclosure is based, may readily be utilized as a basis for the designing of other structures, methods, and systems for carrying out the several purposes of the disclosed subject matter. It is important, therefore, that the claims be regarded as including such equivalent constructions insofar as they do not depart from the spirit and scope of the disclosed subject matter.
Although the disclosed subject matter has been described and illustrated in the foregoing exemplary embodiments, it is understood that the present disclosure has been made only by way of example, and that numerous changes in the details of implementation of the disclosed subject matter may be made without departing from the spirit and scope of the disclosed subject matter, which is limited only by the claims which follow.
This application claims priority under 35 U.S.C. 119(e) to U.S. Provisional Patent Application No. 61/941,106, entitled DHCP Server Enhancement filed Feb. 18, 2014, the contents of which are incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
61941106 | Feb 2014 | US |