This application is related to co-pending U.S. patent application Ser. No. 12/844,892, filed Jul. 28, 2010, entitled “SYSTEM AND METHOD FOR LOCAL PROTECTION AGAINST MALICIOUS SOFTWARE,” Inventors Rishi Bhargava, et al. The disclosure of this application is considered part of and is incorporated by reference herein in its entirety.
This disclosure relates in general to the field of network security and, more particularly, to network level protection against malicious software.
The field of network security has become increasingly important in today's society. The Internet has enabled interconnection of different computer networks all over the world. The ability to effectively protect and maintain stable computers and systems, however, presents a significant obstacle for component manufacturers, system designers, and network operators. This obstacle is made even more complicated due to the continually-evolving array of tactics exploited by malicious operators. Of particular concern more recently are botnets, which may be used for a wide variety of malicious purposes. Once a malicious software program file (e.g., a bot) has infected a host computer, a malicious operator may issue commands from a “command and control server” to control the bot. Bots can be instructed to perform any number of malicious actions such as, for example, sending out spam or malicious emails from the host computer, stealing sensitive information from a business or individual associated with the host computer, propagating the botnet to other host computers, and/or assisting with distributed denial of service attacks. In addition, the malicious operator can sell or otherwise give access to the botnets to other malicious operators through the command and control servers, thereby escalating the exploitation of the host computers. Consequently, botnets provide a powerful way for malicious operators to access other computers and to manipulate those computers for any number of malicious purposes. Security professionals need to develop innovative tools to combat such tactics that allow malicious operators to exploit computers.
To provide a more complete understanding of the present disclosure and features and advantages thereof, reference is made to the following description, taken in conjunction with the accompanying figures, wherein like reference numerals represent like parts, in which:
A method in one example implementation includes receiving information related to a network access attempt on a first computing device with the information identifying a software program file associated with the network access attempt. The method further includes evaluating a first criterion to determine whether network traffic associated with the software program file is permitted and creating a restriction rule to block the network traffic if the network traffic is not permitted. The first criterion includes a trust status of the software program file. In specific embodiments, the method includes pushing the restriction rule to a network protection device that intercepts the network traffic associated with the software program file and that applies the restriction rule to the network traffic. In more specific embodiments, the method includes searching a whitelist identifying trustworthy software program files to determine the trust status of the software program file, where the trust status of the software program file is defined as untrusted if the software program file is not included in the whitelist and the network traffic is not permitted if the trust status of the software program file is defined as untrusted. In yet other specific embodiments, event data related to the network traffic may be logged if the trust status of the software program file associated with the network traffic is defined as untrusted, and such logging may occur instead of blocking the network traffic or may occur in addition to blocking the network traffic.
In example embodiments, local protection components 124 on host 120a, central protection components 135 on central server 130, and network level enforcement components 145 on network protection device 140 may cooperate to provide a system for network level protection against network traffic associated with malicious software. Network traffic, as used herein in this Specification, is intended to mean data in a network such as, for example, electronic packets being sent from a host to any network or other computer (i.e., outbound network traffic), and electronic packets being sent to the host from any network or other computer (i.e., inbound network traffic). Network traffic may be blocked or otherwise restricted by network protection device 140 if network protection device 140 includes an applicable restriction rule associated with an untrusted program file.
In accordance with embodiments of this disclosure, network protection device 140 may receive restriction rules created for network traffic when untrusted program files are discovered. A trust status (i.e., trusted or untrusted) of program files may be determined in a batch mode or may be determined in real-time during a network access attempt. A network access attempt as used herein in this Specification is intended to include any inbound or outbound network access attempt on a host (e.g., accepting a connection request, making a connection request, receiving electronic data from a network, sending electronic data to a network). In both batch mode and real-time mode, program files are evaluated to determine whether the trust status of each program file is defined as trusted or untrusted, using one or more trust evaluation techniques (e.g., whitelist comparisons, program file change comparisons, blacklist comparisons, etc.). Policies may also be used when creating restriction rules. Such policies may include, for example, only allowing access to a specified subnet of network addresses, blocking all inbound and outbound network traffic, blocking only inbound or outbound network traffic, blocking all local network traffic and allowing Internet traffic, and the like. Any network traffic associated with untrusted program files may also be logged and aggregated for reporting.
For purposes of illustrating the techniques of the system for network level protection against malicious software, it is important to understand the activities occurring within a given network. The following foundational information may be viewed as a basis from which the present disclosure may be properly explained. Such information is offered earnestly for purposes of explanation only and, accordingly, should not be construed in any way to limit the broad scope of the present disclosure and its potential applications. In addition, it will be appreciated that the broad scope of this disclosure intends for references to “program file”, “software program file”, and “executable software” to encompass any software file comprising instructions that can be understood and processed on a computer such as, for example, executable files, library modules, object files, other executable modules, script files, interpreter files, and the like.
Typical network environments used in organizations and by individuals include the ability to communicate electronically with other networks using, for example, the Internet to access web pages hosted on servers connected to the Internet, to send or receive electronic mail (i.e., email) messages, or to exchange files with end users or servers connected to the Internet. Malicious users are continuously developing new tactics using the Internet to spread malware and to gain access to confidential information.
Tactics that represent an increasing threat to computer security often include botnets. Botnets use a client-server architecture where a type of malicious software (i.e., a bot) is placed on a host computer and communicates with a command and control server, which may be controlled by a malicious user (e.g., a botnet operator). The bot may receive commands from the command and control server to perform particular malicious activities and, accordingly, may execute such commands. The bot may also send any results or pilfered information back to the command and control server. In addition to receiving commands to perform malicious activities, bots also typically include one or more propagation vectors that enable it to spread within an organization's network or across other networks to other organizations or individuals. Common propagation vectors include exploiting known vulnerabilities on hosts within the local network and sending malicious emails having a malicious program attached or providing malicious links within the emails. Bots may also infect host computers through, for example, drive-by downloads, viruses, worms, Trojan horses, etc.
Botnets provide a powerful way for botnet operators to compromise computer systems by employing a variety of attacks. Once a bot has infected a host computer, the command and control server can issue commands to the bot to perform various types of attacks. Commonly, botnets have been used to send bulk email and to perform distributed denial of service attacks. More recently, however, botnets have been used to perform more targeted attacks against businesses and individuals to obtain confidential data or other sensitive information such as intellectual property and financial data.
Existing firewall and network intrusion prevention technologies are generally deficient in recognizing and containing botnets. Bots are often designed to initiate communication with the command and control server and to masquerade as normal web browser traffic. Bots may be crafted with a command and control protocol that makes the bot appear to be making normal network connections to a web server. For example, a bot may use a port typically used to communicate with a web server. Such bots, therefore, may not be detected by existing technologies without performing more detailed packet inspection of the web traffic. Moreover, once a bot is discovered, the botnet operator may simply find another way to masquerade network traffic by the bot to continue to present as normal web traffic. More recently, botnet operators have crafted bots to use encryption protocols such as, for example, secure socket layer (SSL), thereby encrypting malicious network traffic. Such encrypted traffic may use a Hypertext Transfer Protocol Secure (HTTPS) port such that only the endpoints involved in the encrypted session can decrypt the data. Thus, existing firewalls and other network intrusion prevention technologies are unable to perform any meaningful inspection of the web traffic. Consequently, bots continue to infect host computers within networks.
Other software security technology focused on preventing unauthorized program files from executing on a host computer may have undesirable side effects for end users or employees of a business or other organizational entity. Network or Information Technology (IT) administrators may be charged with crafting extensive policies relevant to all facets of the business entity to enable employees to obtain software and other electronic data from desirable and trusted network resources. Without extensive policies in place, employees may be prevented from downloading software and other electronic data from network resources that are not specifically authorized, even if such software and other data are legitimate and necessary business activities. In addition, such systems may be so restrictive that if unauthorized software is found on a host computer, any host computer activities may be suspended pending network administrator intervention. For businesses, this type of system may interfere with legitimate and necessary business activities, resulting in worker downtime, lost revenue, significant Information Technology (IT) overhead, and the like.
A system and method for network level protection against malicious software, as outlined in
Turning to the infrastructure of
In example embodiments, local network 110 represents a network environment of an organization (e.g., a business, a school, a government entity, a family, etc.), with hosts 120a, 120b, and 120c representing end user computers operated by employees or other individuals associated with the organization. The end user computers may include computing devices such as desktops, laptops, mobile or handheld computing devices (e.g., personal digital assistants (PDAs) or mobile phones), or any other computing device capable of executing software processes associated with network access to local network 110. Connection between hosts 120a, 120b, and 120c, central server 130, secondary server 180, network protection device 145, and any additional components in local network 110 may include any appropriate medium such as, for example, cable, Ethernet, wireless (e.g., WiFi, 3G, 4G, etc.), ATM, fiber optics, etc. It should be noted that the network configurations and interconnections shown and described herein are for illustrative purposes only.
In the example embodiment shown in
Whitelists and blacklists may be implemented using checksums where a unique checksum for each program file is stored, which can be readily compared to a computed checksum of a program file sought to be evaluated. A checksum can be a mathematical value or hash sum (e.g., a fixed string of numerical digits) derived by applying an algorithm to a software program file. If the algorithm is applied to a second software program file that is identical to the first software program file, then the checksums should match. However, if the second software program file is different (e.g., it has been altered in some way, it is a different version of the first software program file, it is a wholly different type of software, etc.) then the checksums are very unlikely to match.
Databases such as global whitelist 165 in
In local network 110 shown in
Central server 130 in local network 110 may include central protection components 135 for determining a trust status of software program files on host 120a, for creating restriction and logging rules for network traffic associated with untrusted software program files, for pushing restriction and logging rules to network protection device 140, and for updating logged events database 131 with entries related to network traffic associated with untrusted program files. In some embodiments central protection components may also update central untrusted software inventory 132 with entries identifying untrusted software program files. Central server 130 may also include or have access to process traffic mapping database 134, which could map software processes to software program files, including information such as program file paths, addresses (e.g., Internet Protocol (IP) addresses), and/or port numbers. Logged events database 131, central untrusted software inventory 132, internal whitelist 133, and process traffic mapping database 134 may be provided in any network and device accessible to central server 130. As will be further described herein, central untrusted software inventory 132 may be omitted in some embodiments of the system. Network protection device 140 may include network level enforcement components 145 for intercepting network traffic (e.g., electronic packets inbound to host 120a or outbound from host 120a, etc.) and enforcing any applicable restriction and logging rules to the intercepted packets.
Turning to
Central server 200 may also include or have access to appropriate hardware and memory elements such as, for example, a logged events database 231 and an internal whitelist 233. In some embodiments, central server 200 may also include or have access to a central untrusted software inventory 232, and in other embodiments central untrusted software inventory 232 may not be a required component of the system. Other hardware elements including a processor 280 and a memory element 290 may also be included in central server 200. Finally, a management console 210 may be suitably connected to central server 200 for authorized persons to deploy, configure, and maintain the system through an administrative component such as administrative protection module 220.
In embodiments using central trusted cache 245, the cache may be implemented in hardware as a block of memory for temporary storage of entries (e.g., checksums) identifying program files that have been previously determined to have a trusted status, such as those program files found during searches of global and/or internal whitelists. Central trusted cache 245 can provide quick and transparent access to data indicating program files previously evaluated for a trust status. Thus, if a requested program file is found in central trusted cache 245 then a search of global and/or internal whitelists, or any other trust evaluation, may not need to be performed. In addition, embodiments using central trusted cache 245 may not need to maintain central untrusted software inventory 232.
Turning to
In various embodiments of the system such as the batch processing embodiment or certain real-time processing embodiments, local protection components may include software program inventory feed 335 with a data flow to central server 200 for pushing an inventory of executable software 340 or an inventory of new and/or changed program files in executable software 340 to central server 200. Event feed 330 and software program inventory feed 335 may reside in the user space of host 300. Also shown in user space of host 300 is an example executing software process 345, which corresponds to one or more of the program files of executable software 340. For ease of reference, executable software 340 is shown in user space on host 300. However, executable software 340 may be stored in a memory element such as disk space of host 300.
Host 300 may also include hardware components such as a network interface card (NIC) device 370, a processor 380, and a memory element 390. Transmission protocols, such as Transmission Control Protocol/Internet Protocol (TCP/IP) 350 and other protocols 360, may reside in a kernel space of host 300.
Not shown in
Turning to
In network protection device 400, filter/firewall 410 may intercept network traffic (e.g., electronic packets outbound from local network 110, inbound to local network 110, or within local network 110) and may query network rules element 420 to determine whether any restriction and/or logging rules apply to the particular intercepted packets of network traffic. If an applicable restriction rule is found, then it is applied to the packets, which may be blocked, rerouted, selectively allowed, and the like. Event log 430 may be provided in network protection device 400 for logging network traffic event data. Network traffic event data may include information related to particular packets received by network protection device 400 such as, for example, source address and port number, destination address and port number, date and time stamp, and/or rule ID (i.e., identifier indicating a restriction or logging rule applied to the intercepted packets). Such logging may occur if network rules element 420 has a logging rule corresponding to the particular packets received by network protection device 400 or if logging is performed by default such as, for example, logging a network traffic event when a restriction rule is applied to packets corresponding to the network traffic event.
In various example embodiments, trust determination, logging, and rule-making activities may be provided by administrative protection module 220, policy module 230, software trust determination module 240, rule making module 250, and process traffic mapping module 260 of central server 200 and by software program inventory feed 335 and/or event feed 330 of host 120a. Information related to the trust determination, logging, and rule making activities can be suitably rendered, or sent to a specific location (e.g., central server 200, network rules element 420, etc.) or simply stored or archived (e.g., logged events database 231, central untrusted software inventory 232, policy database 235, process traffic mapping database 234, central trusted cache 245, etc.), and/or properly displayed in any appropriate format (e.g., through management console 210, etc.). Security technology that relates to one or more of such trust determination, logging, and rule-making activities can include elements of McAfee® software (e.g., ePolicy Orchestrator, Application Control, and/or Change Control) or any other similar software. Thus, any such components may be included within the broad scope of the terms ‘administrative protection module’, ‘policy module’, ‘software trust determination module’, ‘rule making module’, ‘process traffic mapping module’, ‘software program inventory feed’, and ‘event feed’ as used herein in this Specification. Logged events database 231, central untrusted software inventory 232, internal whitelist 233, process traffic mapping database 234, policy database 235, central trusted cache 245, network rules element 420, and event log 430 may include information related to the trust determination, logging, and rule making for electronic data (e.g., trust determinations for program files, network access attempts, destination address and port numbers of software processes, source address and port numbers of software processes, network restriction rules, logging rules, etc.), and these elements can readily cooperate, coordinate, or otherwise interact with the modules and components of host 300, central server 200, and network protection device 400.
Turning to
After receiving the software inventory, flow passes to step 525 where a first program file is retrieved from the software inventory. Flow then passes to step 530 to determine a trust status (i.e., trusted or untrusted) of the program file. Trust status may be determined by software trust determination module 240 of central server 200 using one or more software trust determination techniques (e.g., evaluating internal whitelists, evaluating external whitelists, evaluating state change of program files, evaluating blacklists, etc.), which will be shown and described further herein with reference to
After the program file trust status is determined in step 530, flow passes to step 535 where a query is made as to whether the program file is trusted. If the program file is trusted, then flow passes to step 580 to bypass creating network restriction or logging rules and to continue looping through the software inventory to evaluate each program file. However, if the program file trust status is untrusted in step 535, then flow passes to step 540 where process traffic mapping information is obtained for the untrusted program file from process traffic mapping database 234. The process traffic mapping information may include, for example, source address and destination port number mapped to the program file, which can be used to create rules to log and/or restrict network traffic.
After the process traffic mapping information is retrieved for the program file, a query is made as to whether logging is enabled in step 545. If the query in step 545 indicates that logging is enabled, then flow passes to step 550 where a logging rule may be created and then pushed to network protection device 400 to be stored in network rules element 420. In one example, the source address and destination port number from the process traffic mapping information retrieved in step 540 could be used to create a rule to log particular network event data. In this example, the logging rule could require network traffic event data related to electronic packets intercepted by network protection device 400 to be stored in event log 430 when the intercepted packets have a source address and a destination port matching the process traffic mapping information. In some embodiments, a rule ID identifying the logging rule may be stored in process mapping database 234 and mapped to the untrusted program file.
After the logging rule has been created and pushed to network protection device 400 in step 550, or if logging is not enabled in step 545, then flow passes to step 555 where a query is made as to whether enforcement is enabled. If enforcement is not enabled, then flow passes to step 580 to bypass creating a network restriction rule for the untrusted program file and to continue looping through the software inventory to evaluate the remaining program files in the software inventory. If enforcement is enabled in step 555, however, then policy database 235 may be queried in step 560 to determine whether any configured policy overrides the untrusted status of the program file to allow network traffic associated with the program file. In example embodiments, policy module 230 of central server 200 may allow a network administrator or other authorized user to craft policy configurations through management console 210, and to store such policies in policy database 235. Policy database 235 may then be queried in step 560 for any policies relevant to the untrusted program file.
If a policy is found in policy database 235 that overrides the untrusted status of the program file, then flow passes to step 580 to bypass creating a network restriction rule for the untrusted program file and to continue looping through the software inventory to evaluate the remaining program files in the software inventory. However, if a policy does not override the untrusted status of the program file (i.e., a policy requires some type of restriction rule or no policy is applicable), then flow passes to step 570 where one or more network restriction rules can be created using process traffic mapping information and/or any applicable policies.
Policies may be used to create various types of restriction rules, and these policy configurations may be implemented as desired by particular network owners. In some example embodiments, policy configurations may include one or more broad-based restrictions such as blocking all inbound and outbound network traffic, blocking all inbound network traffic and allowing outbound network traffic, or allowing inbound network traffic and blocking outbound network traffic. More specific strategies may also be employed, such as blocking outbound network traffic to the local network but allowing outbound network traffic to the Internet, or allowing inbound network traffic from a specified subnet of source addresses and/or allowing outbound network traffic to a specified subnet of destination addresses. Finally, even more granular strategies may be used such as blocking specific inbound services and/or specific outbound services on a port (e.g., domain name service (DNS), simple mail transfer protocol (SMTP), Internet Relay Chat (IRC), etc.). These example policy configurations are for illustrative purposes, and are intended to include any other policy configurations to restrict inbound, outbound, and/or local network traffic or any combination thereof. Such policies may be implemented in the system for network level protection by routing network traffic through network protection device 400, which applies network restriction rules created using the configured policies.
Particular policy configurations may be balanced between competing interests such as the need to prevent the propagation and potentially malicious activities of untrusted software and the need to conduct necessary business activities. For example, in a network having a host subnet and a server subnet, a policy may be configured to allow network traffic associated with untrusted program files to access only the server subnet but not the host subnet. This may be desirable because it may prevent the propagation of malicious software to other hosts within the network, while allowing each host uninterrupted access to a secured server subnet. Another policy may block network traffic associated with untrusted program files from accessing the Internet except for a known subnet hosting job critical services. Thus, many different blocking options may be employed by crafting policies allowing selective network access.
In embodiments of the system and method for network level protection, network level specific policies may also be crafted for untrusted program files. For example, a policy may be crafted to redirect network traffic associated with an untrusted program file to another server, such as secondary server 180. In one example, potentially malicious network traffic associated with an untrusted program file could be forced through additional firewalls, filters, antispam/antivirus gateways, proxies, and the like on secondary server 180. In another example, secondary server 180 may be configured to respond with one or more predefined commands upon receiving a network connection. Some bots are designed to self-destruct upon receiving particular commands and secondary server 180 could be configured to respond to a network connection with such commands, thereby causing a bot that has been redirected to secondary server 180 to be destroyed.
Another network level specific policy includes switching virtual local area network (VLAN) membership to another VLAN port. In this example, VLAN membership could be switched for the port associated with an untrusted program file. Although switching VLAN membership to another port would effectively move all of the network traffic on that port rather than individual streams, the alternate VLAN could be configured to force the network traffic through additional firewalls, filters, antispam and antivirus gateways, proxies, and the like. This type of restriction could be particularly useful if network protection device 400 is configured as a layer 2 managed switch.
In another example embodiment, network protection device 400 may be adapted to do a deeper packet inspection to determine whether multiple conversation streams are being transferred over a single port and to identify the stream associated with the untrusted program file to which the applicable network restriction and logging rules apply. Thus, in this embodiment, a policy could be configured so that network restriction or logging rules are crafted to selectively block and/or log the particular stream associated with the untrusted program file, while allowing other streams to continue connections over the same port.
Turning back to step 570 of
Turning to
If the program file is not found on any internal or external whitelist in steps 610 and 620, however, then the program file has an untrusted status. Flow may then move to step 630 where the program file may be evaluated to determine whether any predefined condition exists that allows the program file to be promoted from the untrusted status to a trusted status. Such predefined conditions may include heuristic considerations such as, for example, software owned by an administrator, file access controls, file attributes (e.g., creation time, modification time, etc.), and the like. In one example, an untrusted program file owned by an administrator could be promoted to a trusted status and, therefore, flow could end and the trust status could be returned to step 530 of
Trust determination flow 600 may also include additional logic (not shown) to evaluate blacklists in addition to whitelists. Blacklists identify software program files known to be malicious. Blacklists may be provided by numerous sources including Artemis and Anti-Virus databases provided by McAfee, Inc., and locally maintained blacklists within a local network. In this embodiment, if the program file is found on any internal or external blacklist, then the program file is defined as untrusted.
Turning to
Referring again to step 720 of
Alternative implementations to enumerate program files and to determine a trust status will be readily apparent. Embodiments previously shown and described herein refer to enumerating an inventory of executable software on each host in a network, such as host 300, pushing the software inventory to central server 200 and determining the trust status associated with each program file in the inventory. In alternative embodiments, however, the trust determination of software program files could be locally performed by each host and resulting information could be pushed to another location (e.g., central server 200) and/or maintained locally on a local untrusted software inventory.
Locally determining a trust status of software program files could be performed by whitelist evaluations, blacklist evaluations, state change evaluations, or any other suitable trust evaluation technique. In such embodiments an inventory of executable software may be enumerated by, for example, McAfee® software (e.g., Policy Auditor, Application Control, or Change Control). When performing whitelist evaluations as shown in
The batch processing embodiments shown and described with reference to
Other businesses may prefer tighter control and a closed by default approach could be implemented in an alternative embodiment. In the closed by default approach, network protection device 400 could be configured to block all network traffic unless specifically permitted by a rule. All electronic packets intercepted by network protection device 400 could be evaluated to determine whether network rules element 420 contains a rule specifically permitting the intercepted packets to be transmitted (e.g., packets having an allowed source address and port number, packets having an allowed destination address and port number, etc.). In such an embodiment, permission rules, rather than restriction rules, could be created and pushed to network protection device 400 whenever new program files are determined to have a trusted status.
Turning to
Once the network access attempt has been intercepted, a process traffic mapping element provided, for example, in the operating system kernel of host 300 may be queried to determine which program files (e.g., executable files, library modules, object files, other executable modules, script files, interpreter files, etc.) correspond to the network access attempt associated with software process 345. In this example, the network access attempt is mapped to executing software process 345, which could be mapped to an executable file and one or more library modules loaded into executing software process 345. Thus, the host event information that is pushed to central server 200 may include program file paths for the one or more identified program files, the associated program file hashes, a source address and port, and/or a destination address and port of the network access attempt.
After the host event information is received by central server 200 in step 810, flow passes to step 820 to get a trust status of the program files associated with the network access attempt. Determining the trust status of the program files can be accomplished using various techniques, which will be shown and described in more detail in a first embodiment in
After obtaining the trust status for each of the program files associated with the network access attempt in step 820, flow passes to step 830, which may be implemented, at least in part, as process traffic mapping module 260 of central server 200. In step 830, if any of the program files have an untrusted status, then the host event information may be used to populate process traffic mapping database 234. For example, detailed port and address information and program file path information associated with the program files may be added to process traffic mapping database 234. Flow then passes to step 835 and a query is made as to whether all program files associated with the network access attempt have a trusted status, and if so, flow ends without creating logging or restriction rules for network traffic associated with the program files. However, if any of the program files has an untrusted status, then flow passes to step 845 to determine whether logging is enabled.
If logging is enabled, then flow passes to step 850 where a logging rule may be created and pushed to network protection device 400 to be stored in network rules element 420. In one example, the source address and port number and the destination address and port number from the host event information could be used to create a rule to log particular network event data. In this example, the logging rule could require network traffic event data related to electronic packets intercepted by network protection device 400 to be stored in event log 430 when the intercepted packets have a source address, a source port, a destination address, and a destination port matching the host event information. In some embodiments, a rule ID identifying the logging rule may be stored in process traffic mapping database 234 and mapped to the program files associated with the network access attempt.
After the logging rule has been created and pushed to network protection device 400 in step 850, or if logging was not enabled in step 845, flow passes to step 855 to determine whether enforcement is enabled. If enforcement is not enabled, then the flow ends without creating restriction rules for network traffic associated with the one or more untrusted program files. If enforcement is enabled in step 855, however, then policy database 235 may be queried in step 860 to determine whether any configured policy overrides the untrusted status of the program files to allow network traffic associated with the program files. If such a policy is found, then flow ends without creating a restriction rule. However, if a policy does not override the untrusted status of the program file (i.e., a policy requires some type of restriction rule or no policy is applicable), then flow passes to step 870 where one or more network restriction rules can be created using host event information and/or any applicable policies and then pushed to network protection device 400. In one example, the host event information could be used to create a restriction rule to block any inbound, outbound, and/or local packets having a source address and port and destination address and port matching the source address and port and destination address and port from the host event information. The use of policies to create restriction rules and examples of such policies, including network level specific policies, have been previously described herein with reference to the batch processing flow of
After the restriction rule has been created using host event information and/or any applicable policies, the restriction rule is pushed to network protection device 400 and stored in network rules element 420 and then the flow ends. In this real-time embodiment, a time-delay may be configured in host 300 after the network access attempt has been intercepted in order to allow real-time processing flow 800 sufficient time to create any necessary rules and push such rules to network protection device 400. In another embodiment, the network access attempt may be held on host 300 until central server 200 acknowledges to host 300 that it has updated process traffic mapping database 234 with mapping information for the network access attempt and/or that it has pushed any resulting logging or restriction rules to network protection device 400. This acknowledgement could be accomplished, for example, via a signal over bidirectional data flow to event feed 330 on host 300.
Turning to
Turning to
Beginning in step 1010, a query is made as to whether all program files associated with the network access attempt are found in central trusted cache 245. If all of the program files are found in central trusted cache 245, then all of the program files have a trusted status. Consequently, flow ends and the trust statuses are returned to step 820 of
Real-time trust determination flow 1000 may also include additional logic to evaluate a program file not found in any whitelist and consequently having an untrusted status to determine whether a predefined condition exists that allows the untrusted program file to be promoted to a trusted status. Such predefined conditions may include heuristic considerations, which have been previously shown and described herein with reference to
Turning to
After the log records are retrieved from network protection device 400, flow passes to step 1220 where information may be retrieved from process traffic mapping database 234. Process traffic mapping database 234 may provide user-understandable information, such as program file paths and host identification, corresponding to the network traffic event data in the log record. For example, a destination address and port and a source address and port from a log record may be mapped to an untrusted program file path in process traffic mapping database 234. In another example, a rule ID could be used from a log record to find a mapping to an untrusted program file path in process traffic mapping database 234 or, alternatively, in some other separate database or record.
After the user-understandable information is retrieved from process traffic mapping database 234, flow passes to step 1230 where logged events database 231 can be updated with network traffic event data from the log records and any corresponding process traffic mapping information. Examples of possible network traffic event data and corresponding process traffic mapping information stored in logged events database 231 include data associated with intercepted packets such as program file paths, identification of the hosts, a date and time stamp, source address and port numbers, destination address and port numbers, and the like.
With both the batch processing embodiments and the real-time embodiments, flow 1200 may be configured to run at any predetermined intervals of time (e.g., weekly, daily, hourly, etc.). Flow 1200 may, in some embodiments, be implemented as part of administrative protection module 220. Alternatively, in the batch processing embodiments, flow 1200 may be implemented as part of flow 500 shown in
Software for achieving the operations outlined herein can be provided at various locations (e.g., the corporate IT headquarters, end user computers, distributed servers in the cloud, etc.). In other embodiments, this software could be received or downloaded from a web server (e.g., in the context of purchasing individual end-user licenses for separate networks, devices, servers, etc.) in order to provide this system for network level protection against malicious software. In one example implementation, this software is resident in one or more computers sought to be protected from a security attack (or protected from unwanted or unauthorized manipulations of data).
In other examples, the software of the system for network level protection against malicious software could involve a proprietary element (e.g., as part of a network security solution with McAfee® Application Control software, McAfee® Change Control software, McAfee® ePolicy Orchestrator software, McAfee® Policy Auditor software, McAfee® Artemis Technology software, McAfee® Host Intrusion Prevention software, McAfee® VirusScan software, etc.), which could be provided in (or be proximate to) these identified elements, or be provided in any other device, server, network appliance, console, firewall, switch, router, information technology (IT) device, distributed server, etc., or be provided as a complementary solution (e.g., in conjunction with a firewall), or provisioned somewhere in the network.
In an example local network 110 as shown in
In certain example implementations, the activities involved in network level protection against malicious software outlined herein may be implemented in software. This could be inclusive of software provided in central servers 130 (e.g., central protection components 135), hosts 120 (e.g., local protection components 124), network protection device (e.g., network level enforcement components 145), and/or secondary server 180. These components, elements and/or modules can cooperate with each other in order to perform activities to provide network level protection against malicious software such as botnets, as discussed herein. In other embodiments, these features may be provided external to these elements, included in other devices to achieve these intended functionalities, or consolidated in any appropriate manner. For example, the protection activities could be further localized in hosts 120 or further centralized in central server 130, and some of the illustrated processors may be removed, or otherwise consolidated to accommodate the particular system configuration. In a general sense, the arrangement depicted in
All of these elements (hosts 120, central server 130, network protection device 140, and/or secondary server 180) include software (or reciprocating software) that can coordinate, manage, or otherwise cooperate in order to achieve the protection activities, including trust determination, logging, enforcement, intercepting, as outlined herein. In addition, one or all of these elements may include any suitable algorithms, hardware, software, components, modules, interfaces, or objects that facilitate the operations thereof. In the implementations involving software, such a configuration may be inclusive of logic encoded in one or more tangible media (e.g., embedded logic provided in an application specific integrated circuit (ASIC), digital signal processor (DSP) instructions, software (potentially inclusive of object code and source code) to be executed by a processor, or other similar machine, etc.), with the tangible media being inclusive of non-transitory tangible media. In some of these instances, one or more memory elements (as shown in various FIGURES including
Any of these elements (e.g., a computer, a server, a network protection device, a firewall, distributed server, etc.) can include memory elements for storing information to be used in achieving the protection activities as outlined herein. These devices may further keep information in any suitable memory element (e.g., random access memory (RAM), ROM, EPROM, EEPROM, ASIC, etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs. Any of the memory items discussed herein (e.g., logged events database, central untrusted software inventory, local untrusted software inventory, internal whitelist, policy database, process traffic mapping database, central trusted cache, network rules element, event log, etc.) should be construed as being encompassed within the broad term ‘memory element.’ Similarly, any of the potential processing elements, modules, and machines described in this Specification should be construed as being encompassed within the broad term ‘processor.’ Each of the computers, hosts, network protection devices, servers, distributed servers, etc. may also include suitable interfaces for receiving, transmitting, and/or otherwise communicating data or information in a network environment.
Note that with the examples provided herein, interaction may be described in terms of two, three, four, or more network components. However, this has been done for purposes of clarity and example only. It should be appreciated that the system for network level protection against malicious software can be consolidated in any suitable manner. Along similar design alternatives, any of the illustrated computers, modules, components, and elements of the FIGURES may be combined in various possible configurations, all of which are clearly within the broad scope of this Specification. In certain cases, it may be easier to describe one or more of the functionalities of a given set of flows by only referencing a limited number of components or network elements. Therefore, it should also be appreciated that the system of
It is also important to note that the operations described with reference to the preceding FIGURES illustrate only some of the possible scenarios that may be executed by, or within, the system for network level protection against malicious software. Some of these operations may be deleted or removed where appropriate, or these operations may be modified or changed considerably without departing from the scope of the discussed concepts. In addition, the timing of these operations may be altered considerably and still achieve the results taught in this disclosure. For example, trust determination by searching whitelists may be performed by searching internal whitelists prior to searching external or global whitelists. The preceding operational flows have been offered for purposes of example and discussion. Substantial flexibility is provided by the system in that any suitable arrangements, chronologies, configurations, and timing mechanisms may be provided without departing from the teachings of the discussed concepts.
Number | Name | Date | Kind |
---|---|---|---|
4688169 | Joshi | Aug 1987 | A |
4982430 | Frezza et al. | Jan 1991 | A |
5155847 | Kirouac et al. | Oct 1992 | A |
5222134 | Waite et al. | Jun 1993 | A |
5390314 | Swanson | Feb 1995 | A |
5521849 | Adelson et al. | May 1996 | A |
5560008 | Johnson et al. | Sep 1996 | A |
5699513 | Feigen et al. | Dec 1997 | A |
5778226 | Adams et al. | Jul 1998 | A |
5778349 | Okonogi | Jul 1998 | A |
5787427 | Benantar et al. | Jul 1998 | A |
5842017 | Hookway et al. | Nov 1998 | A |
5907709 | Cantey et al. | May 1999 | A |
5907860 | Garibay et al. | May 1999 | A |
5926832 | Wing et al. | Jul 1999 | A |
5944839 | Isenberg | Aug 1999 | A |
5974149 | Leppek | Oct 1999 | A |
5987610 | Franczek et al. | Nov 1999 | A |
5987611 | Freund | Nov 1999 | A |
5991881 | Conklin et al. | Nov 1999 | A |
6064815 | Hohensee et al. | May 2000 | A |
6073142 | Geiger et al. | Jun 2000 | A |
6141698 | Krishnan et al. | Oct 2000 | A |
6192401 | Modiri et al. | Feb 2001 | B1 |
6192475 | Wallace | Feb 2001 | B1 |
6256773 | Bowman-Amuah | Jul 2001 | B1 |
6275938 | Bond et al. | Aug 2001 | B1 |
6321267 | Donaldson | Nov 2001 | B1 |
6338149 | Ciccone, Jr. et al. | Jan 2002 | B1 |
6356957 | Sanchez, II et al. | Mar 2002 | B2 |
6393465 | Leeds | May 2002 | B2 |
6442686 | McArdle et al. | Aug 2002 | B1 |
6449040 | Fujita | Sep 2002 | B1 |
6453468 | D'Souza | Sep 2002 | B1 |
6460050 | Pace et al. | Oct 2002 | B1 |
6496477 | Perkins et al. | Dec 2002 | B1 |
6587877 | Douglis et al. | Jul 2003 | B1 |
6611925 | Spear | Aug 2003 | B1 |
6658645 | Akuta et al. | Dec 2003 | B1 |
6662219 | Nishanov et al. | Dec 2003 | B1 |
6748534 | Gryaznov et al. | Jun 2004 | B1 |
6769008 | Kumar et al. | Jul 2004 | B1 |
6769115 | Oldman | Jul 2004 | B1 |
6795966 | Lim et al. | Sep 2004 | B1 |
6832227 | Seki et al. | Dec 2004 | B2 |
6834301 | Hanchett | Dec 2004 | B1 |
6847993 | Novaes et al. | Jan 2005 | B1 |
6907600 | Neiger et al. | Jun 2005 | B2 |
6918110 | Hundt et al. | Jul 2005 | B2 |
6930985 | Rathi et al. | Aug 2005 | B1 |
6934755 | Saulpaugh et al. | Aug 2005 | B1 |
6988101 | Ham et al. | Jan 2006 | B2 |
6988124 | Douceur et al. | Jan 2006 | B2 |
7007302 | Jagger et al. | Feb 2006 | B1 |
7010796 | Strom et al. | Mar 2006 | B1 |
7024548 | O'Toole, Jr. | Apr 2006 | B1 |
7039949 | Cartmell et al. | May 2006 | B2 |
7054930 | Cheriton | May 2006 | B1 |
7065767 | Kambhammettu et al. | Jun 2006 | B2 |
7069330 | McArdle et al. | Jun 2006 | B1 |
7082456 | Mani-Meitav et al. | Jul 2006 | B2 |
7093239 | van der Made | Aug 2006 | B1 |
7096500 | Roberts et al. | Aug 2006 | B2 |
7124409 | Davis et al. | Oct 2006 | B2 |
7139916 | Billingsley et al. | Nov 2006 | B2 |
7152148 | Williams et al. | Dec 2006 | B2 |
7159036 | Hinchliffe et al. | Jan 2007 | B2 |
7177267 | Oliver et al. | Feb 2007 | B2 |
7203864 | Goin et al. | Apr 2007 | B2 |
7251655 | Kaler et al. | Jul 2007 | B2 |
7290266 | Gladstone et al. | Oct 2007 | B2 |
7302558 | Campbell et al. | Nov 2007 | B2 |
7330849 | Gerasoulis et al. | Feb 2008 | B2 |
7340684 | Ramamoorthy et al. | Mar 2008 | B2 |
7346781 | Cowle et al. | Mar 2008 | B2 |
7349931 | Horne | Mar 2008 | B2 |
7350204 | Lambert et al. | Mar 2008 | B2 |
7353501 | Tang et al. | Apr 2008 | B2 |
7363022 | Whelan et al. | Apr 2008 | B2 |
7370360 | van der Made | May 2008 | B2 |
7385938 | Beckett et al. | Jun 2008 | B1 |
7406517 | Hunt et al. | Jul 2008 | B2 |
7441265 | Staamann et al. | Oct 2008 | B2 |
7464408 | Shah et al. | Dec 2008 | B1 |
7506155 | Stewart et al. | Mar 2009 | B1 |
7506170 | Finnegan | Mar 2009 | B2 |
7506364 | Vayman | Mar 2009 | B2 |
7546333 | Alon et al. | Jun 2009 | B2 |
7546594 | McGuire et al. | Jun 2009 | B2 |
7552479 | Conover et al. | Jun 2009 | B1 |
7577995 | Chebolu et al. | Aug 2009 | B2 |
7603552 | Sebes et al. | Oct 2009 | B1 |
7607170 | Chesla | Oct 2009 | B2 |
7657599 | Smith | Feb 2010 | B2 |
7669195 | Qumei | Feb 2010 | B1 |
7685635 | Vega et al. | Mar 2010 | B2 |
7698744 | Fanton et al. | Apr 2010 | B2 |
7703090 | Napier et al. | Apr 2010 | B2 |
7739497 | Fink et al. | Jun 2010 | B1 |
7757269 | Roy-Chowdhury et al. | Jul 2010 | B1 |
7765538 | Zweifel et al. | Jul 2010 | B2 |
7783735 | Sebes et al. | Aug 2010 | B1 |
7809704 | Surendran et al. | Oct 2010 | B2 |
7818377 | Whitney et al. | Oct 2010 | B2 |
7823148 | Deshpande et al. | Oct 2010 | B2 |
7836504 | Ray et al. | Nov 2010 | B2 |
7840968 | Sharma et al. | Nov 2010 | B1 |
7849507 | Bloch et al. | Dec 2010 | B1 |
7853643 | Martinez et al. | Dec 2010 | B1 |
7856661 | Sebes et al. | Dec 2010 | B1 |
7865931 | Stone et al. | Jan 2011 | B1 |
7870387 | Bhargava et al. | Jan 2011 | B1 |
7873955 | Sebes et al. | Jan 2011 | B1 |
7895573 | Bhargava et al. | Feb 2011 | B1 |
7908653 | Brickell et al. | Mar 2011 | B2 |
7937455 | Saha et al. | May 2011 | B2 |
7950056 | Satish et al. | May 2011 | B1 |
7966659 | Wilkinson et al. | Jun 2011 | B1 |
7996836 | McCorkendale et al. | Aug 2011 | B1 |
8015388 | Rihan et al. | Sep 2011 | B1 |
8015563 | Araujo et al. | Sep 2011 | B2 |
8028340 | Sebes et al. | Sep 2011 | B2 |
8195931 | Sharma et al. | Jun 2012 | B1 |
8205188 | Ramamoorthy et al. | Jun 2012 | B2 |
8234709 | Viljoen et al. | Jul 2012 | B2 |
8234713 | Roy-Chowdhury et al. | Jul 2012 | B2 |
8307437 | Sebes et al. | Nov 2012 | B2 |
8321932 | Bhargava et al. | Nov 2012 | B2 |
8332929 | Bhargava et al. | Dec 2012 | B1 |
8352930 | Sebes et al. | Jan 2013 | B1 |
8381284 | Dang et al. | Feb 2013 | B2 |
8515075 | Saraf et al. | Aug 2013 | B1 |
8539063 | Sharma et al. | Sep 2013 | B1 |
8544003 | Sawhney et al. | Sep 2013 | B1 |
8549003 | Bhargava et al. | Oct 2013 | B1 |
8549546 | Sharma et al. | Oct 2013 | B2 |
8555404 | Sebes et al. | Oct 2013 | B1 |
8561051 | Sebes et al. | Oct 2013 | B2 |
8561082 | Sharma et al. | Oct 2013 | B2 |
8701182 | Bhargava et al. | Apr 2014 | B2 |
8707422 | Bhargava et al. | Apr 2014 | B2 |
8707446 | Roy-Chowdhury et al. | Apr 2014 | B2 |
8713668 | Cooper et al. | Apr 2014 | B2 |
20020056076 | van der Made | May 2002 | A1 |
20020069367 | Tindal et al. | Jun 2002 | A1 |
20020083175 | Afek et al. | Jun 2002 | A1 |
20020099671 | Mastin et al. | Jul 2002 | A1 |
20020114319 | Liu et al. | Aug 2002 | A1 |
20030014667 | Kolichtchak | Jan 2003 | A1 |
20030023736 | Abkemeier | Jan 2003 | A1 |
20030033510 | Dice | Feb 2003 | A1 |
20030065945 | Lingafelt et al. | Apr 2003 | A1 |
20030073894 | Chiang et al. | Apr 2003 | A1 |
20030074552 | Olkin et al. | Apr 2003 | A1 |
20030115222 | Oashi et al. | Jun 2003 | A1 |
20030120601 | Ouye et al. | Jun 2003 | A1 |
20030120811 | Hanson et al. | Jun 2003 | A1 |
20030120935 | Teal et al. | Jun 2003 | A1 |
20030145232 | Poletto et al. | Jul 2003 | A1 |
20030163718 | Johnson et al. | Aug 2003 | A1 |
20030167292 | Ross | Sep 2003 | A1 |
20030167399 | Audebert et al. | Sep 2003 | A1 |
20030200332 | Gupta et al. | Oct 2003 | A1 |
20030212902 | van der Made | Nov 2003 | A1 |
20030220944 | Schottland et al. | Nov 2003 | A1 |
20030221190 | Deshpande et al. | Nov 2003 | A1 |
20040003258 | Billingsley et al. | Jan 2004 | A1 |
20040015554 | Wilson | Jan 2004 | A1 |
20040051736 | Daniell | Mar 2004 | A1 |
20040054928 | Hall | Mar 2004 | A1 |
20040088398 | Barlow | May 2004 | A1 |
20040139206 | Claudatos et al. | Jul 2004 | A1 |
20040143749 | Tajali et al. | Jul 2004 | A1 |
20040167906 | Smith et al. | Aug 2004 | A1 |
20040172551 | Fielding et al. | Sep 2004 | A1 |
20040230963 | Rothman et al. | Nov 2004 | A1 |
20040243678 | Smith et al. | Dec 2004 | A1 |
20040255161 | Cavanaugh | Dec 2004 | A1 |
20040268149 | Aaron | Dec 2004 | A1 |
20050005006 | Chauffour et al. | Jan 2005 | A1 |
20050018651 | Yan et al. | Jan 2005 | A1 |
20050071633 | Rothstein | Mar 2005 | A1 |
20050086047 | Uchimoto et al. | Apr 2005 | A1 |
20050091321 | Daniell et al. | Apr 2005 | A1 |
20050108516 | Balzer et al. | May 2005 | A1 |
20050108562 | Khazan et al. | May 2005 | A1 |
20050114672 | Duncan et al. | May 2005 | A1 |
20050132346 | Tsantilis | Jun 2005 | A1 |
20050198519 | Tamura et al. | Sep 2005 | A1 |
20050228990 | Kato et al. | Oct 2005 | A1 |
20050235360 | Pearson | Oct 2005 | A1 |
20050257207 | Blumfield et al. | Nov 2005 | A1 |
20050257265 | Cook et al. | Nov 2005 | A1 |
20050260996 | Groenendaal | Nov 2005 | A1 |
20050262558 | Usov | Nov 2005 | A1 |
20050273858 | Zadok et al. | Dec 2005 | A1 |
20050283823 | Okajo et al. | Dec 2005 | A1 |
20050289538 | Black-Ziegelbein et al. | Dec 2005 | A1 |
20060004875 | Baron et al. | Jan 2006 | A1 |
20060015501 | Sanamrad et al. | Jan 2006 | A1 |
20060037016 | Saha et al. | Feb 2006 | A1 |
20060072451 | Ross | Apr 2006 | A1 |
20060075478 | Hyndman et al. | Apr 2006 | A1 |
20060080656 | Cain et al. | Apr 2006 | A1 |
20060085785 | Garrett | Apr 2006 | A1 |
20060101277 | Meenan et al. | May 2006 | A1 |
20060133223 | Nakamura et al. | Jun 2006 | A1 |
20060136910 | Brickell et al. | Jun 2006 | A1 |
20060136911 | Robinson et al. | Jun 2006 | A1 |
20060143713 | Challener et al. | Jun 2006 | A1 |
20060195906 | Jin et al. | Aug 2006 | A1 |
20060200863 | Ray et al. | Sep 2006 | A1 |
20060230314 | Sanjar et al. | Oct 2006 | A1 |
20060236398 | Trakic et al. | Oct 2006 | A1 |
20060259734 | Sheu et al. | Nov 2006 | A1 |
20060277603 | Kelso et al. | Dec 2006 | A1 |
20070011746 | Malpani et al. | Jan 2007 | A1 |
20070028303 | Brennan | Feb 2007 | A1 |
20070033645 | Jones | Feb 2007 | A1 |
20070039049 | Kupferman et al. | Feb 2007 | A1 |
20070050579 | Hall et al. | Mar 2007 | A1 |
20070050764 | Traut | Mar 2007 | A1 |
20070074199 | Schoenberg | Mar 2007 | A1 |
20070083522 | Nord et al. | Apr 2007 | A1 |
20070101435 | Konanka et al. | May 2007 | A1 |
20070136579 | Levy et al. | Jun 2007 | A1 |
20070143851 | Nicodemus et al. | Jun 2007 | A1 |
20070157303 | Pankratov | Jul 2007 | A1 |
20070169079 | Keller et al. | Jul 2007 | A1 |
20070192329 | Croft et al. | Aug 2007 | A1 |
20070220061 | Tirosh et al. | Sep 2007 | A1 |
20070220507 | Back et al. | Sep 2007 | A1 |
20070253430 | Minami et al. | Nov 2007 | A1 |
20070256138 | Gadea et al. | Nov 2007 | A1 |
20070271561 | Winner et al. | Nov 2007 | A1 |
20070300215 | Bardsley | Dec 2007 | A1 |
20080005737 | Saha et al. | Jan 2008 | A1 |
20080005798 | Ross | Jan 2008 | A1 |
20080010304 | Vempala et al. | Jan 2008 | A1 |
20080022384 | Yee et al. | Jan 2008 | A1 |
20080034416 | Kumar et al. | Feb 2008 | A1 |
20080034418 | Venkatraman et al. | Feb 2008 | A1 |
20080052468 | Speirs et al. | Feb 2008 | A1 |
20080082977 | Araujo et al. | Apr 2008 | A1 |
20080120499 | Zimmer et al. | May 2008 | A1 |
20080141371 | Bradicich et al. | Jun 2008 | A1 |
20080163207 | Reumann et al. | Jul 2008 | A1 |
20080163210 | Bowman et al. | Jul 2008 | A1 |
20080165952 | Smith et al. | Jul 2008 | A1 |
20080184373 | Traut et al. | Jul 2008 | A1 |
20080235534 | Schunter et al. | Sep 2008 | A1 |
20080282080 | Hyndman et al. | Nov 2008 | A1 |
20080294703 | Craft et al. | Nov 2008 | A1 |
20080301770 | Kinder | Dec 2008 | A1 |
20080307524 | Singh et al. | Dec 2008 | A1 |
20090007100 | Field et al. | Jan 2009 | A1 |
20090038017 | Durham et al. | Feb 2009 | A1 |
20090043993 | Ford et al. | Feb 2009 | A1 |
20090055693 | Budko et al. | Feb 2009 | A1 |
20090063665 | Bagepalli et al. | Mar 2009 | A1 |
20090113110 | Chen et al. | Apr 2009 | A1 |
20090144300 | Chatley et al. | Jun 2009 | A1 |
20090150639 | Ohata | Jun 2009 | A1 |
20090249053 | Zimmer et al. | Oct 2009 | A1 |
20090249438 | Litvin et al. | Oct 2009 | A1 |
20090320140 | Sebes et al. | Dec 2009 | A1 |
20090328144 | Sherlock et al. | Dec 2009 | A1 |
20090328185 | van den Berg et al. | Dec 2009 | A1 |
20100049973 | Chen | Feb 2010 | A1 |
20100071035 | Budko et al. | Mar 2010 | A1 |
20100100970 | Chowdhury et al. | Apr 2010 | A1 |
20100114825 | Siddegowda | May 2010 | A1 |
20100138430 | Gotou | Jun 2010 | A1 |
20100188976 | Rahman et al. | Jul 2010 | A1 |
20100250895 | Adams et al. | Sep 2010 | A1 |
20100281133 | Brendel | Nov 2010 | A1 |
20100293225 | Sebes et al. | Nov 2010 | A1 |
20100332910 | Ali et al. | Dec 2010 | A1 |
20110029772 | Fanton et al. | Feb 2011 | A1 |
20110035423 | Kobayashi et al. | Feb 2011 | A1 |
20110047542 | Dang et al. | Feb 2011 | A1 |
20110047543 | Mohinder | Feb 2011 | A1 |
20110077948 | Sharma et al. | Mar 2011 | A1 |
20110078550 | Nabutovsky | Mar 2011 | A1 |
20110093842 | Sebes | Apr 2011 | A1 |
20110093950 | Bhargava et al. | Apr 2011 | A1 |
20110113467 | Agarwal et al. | May 2011 | A1 |
20110119760 | Sebes et al. | May 2011 | A1 |
20110138461 | Bhargava et al. | Jun 2011 | A1 |
20110302647 | Bhattacharya et al. | Dec 2011 | A1 |
20120030731 | Bhargava et al. | Feb 2012 | A1 |
20120110666 | Ogilvie | May 2012 | A1 |
20120216271 | Cooper et al. | Aug 2012 | A1 |
20120278853 | Chowdhury et al. | Nov 2012 | A1 |
20120290827 | Bhargava et al. | Nov 2012 | A1 |
20120290828 | Bhargava et al. | Nov 2012 | A1 |
20120297176 | Bhargava et al. | Nov 2012 | A1 |
20130024934 | Sebes et al. | Jan 2013 | A1 |
20130091318 | Bhattacharjee et al. | Apr 2013 | A1 |
20130097355 | Dang et al. | Apr 2013 | A1 |
20130097356 | Dang et al. | Apr 2013 | A1 |
20130097658 | Cooper et al. | Apr 2013 | A1 |
20130097692 | Cooper et al. | Apr 2013 | A1 |
20130117823 | Dang et al. | May 2013 | A1 |
20130246044 | Sharma et al. | Sep 2013 | A1 |
20130246393 | Saraf et al. | Sep 2013 | A1 |
20130246423 | Bhargava et al. | Sep 2013 | A1 |
20130246685 | Bhargava et al. | Sep 2013 | A1 |
20130247016 | Sharma et al. | Sep 2013 | A1 |
20130247027 | Shah et al. | Sep 2013 | A1 |
20130247032 | Bhargava et al. | Sep 2013 | A1 |
20130247181 | Saraf et al. | Sep 2013 | A1 |
20130247192 | Krasser et al. | Sep 2013 | A1 |
20130247226 | Sebes et al. | Sep 2013 | A1 |
20140101783 | Bhargava et al. | Apr 2014 | A1 |
Number | Date | Country |
---|---|---|
1383295 | Dec 2002 | CN |
103283202 | Sep 2013 | CN |
1 482 394 | Dec 2004 | EP |
2 037 657 | Mar 2009 | EP |
2599026 | Jun 2013 | EP |
2004524598 | Aug 2004 | JP |
WO 9844404 | Oct 1998 | WO |
WO 0184285 | Nov 2001 | WO |
WO 2006012197 | Feb 2006 | WO |
WO 2006124832 | Nov 2006 | WO |
WO 2007016478 | Feb 2007 | WO |
WO 2008054997 | May 2008 | WO |
WO 2011059877 | May 2011 | WO |
WO 2012015485 | Feb 2012 | WO |
WO 2012015489 | Feb 2012 | WO |
WO 2012116098 | Aug 2012 | WO |
WO 2013058940 | Apr 2013 | WO |
WO 2013058944 | Apr 2013 | WO |
Entry |
---|
Kurt Gutzmann, “Access Control and Session Management in the HTTP Environment,” Jan./Feb. 2001, pp. 26-35, IEEE Internet Computing. |
U.S. Appl. No. 11/379,953, entitled “Software Modification by Group to Minimize Breakage,” filed Apr. 24, 2006, Inventor(s): E. John Sebes et al. |
U.S. Appl. No. 11/277,596, entitled “Execution Environment File Inventory,” filed Mar. 27, 2006, Inventor(s): Rishi Bhargava et al. |
U.S. Appl. No. 10/651,591, entitled “Method and System for Containment of Networked Application Client Software by Explicit Human Input,” filed Aug. 29, 2003, Inventor(s): Rosen Sharma et al. |
U.S. Appl. No. 10/806,578, entitled Containment of Network communication, filed Mar. 22, 2004, Inventor(s): E. John Sebes et al. |
U.S. Appl. No. 10/739,230, entitled “Method and System for Containment of Usage of Language Interfaces,” filed Dec. 17, 2003, Inventor(s): Rosen Sharma et al. |
U.S. Appl. No. 10/935,772, entitled “Solidifying the Executable Software Set of a Computer,” filed Sep. 7, 2004, Inventor(s): E. John Sebes et al. |
U.S. Appl. No. 11/060,683, entitled “Distribution and Installation of Solidified Software on a Computer,” Filed Feb. 16, 2005, Inventor(s): Bakul Shah et al. |
U.S. Appl. No. 11/346,741, entitled “Enforcing Alignment of Approved Changes and Deployed Changes in the Software Change Life-Cycle,” filed Feb. 2, 2006, Inventor(s): Rahul Roy-Chowdhury et al. |
U.S. Appl. No. 11/182,320, entitled “Classification of Software on Networked Systems,” filed Jul. 14, 2005, Inventor(s): E. John Sebes et al. |
U.S. Appl. No. 11/400,085, entitled “Program-Based Authorization,” filed Apr. 7, 2006, Inventor(s): Rishi Bhargava et al. |
U.S. Appl. No. 11/437,317, entitled “Connectivity-Based Authorization,” filed May 18, 2006, Inventor(s): E. John Sebes et al. |
U.S. Appl. No. 12/290,380, entitled “Application Change Control,” filed Oct. 29, 2008, Inventor(s): Rosen Sharma et al. |
U.S. Appl. No. 12/008,274, entitled Method and Apparatus for Process Enforced Configuration Management, filed Jan. 9, 2008, Inventor(s): Rishi Bhargava et al. |
U.S. Appl. No. 12/291,232, entitled “Method of and System for Computer System State Checks,” filed Nov. 7, 2008, inventor(s): Rishi Bhargava et al. |
U.S. Appl. No. 12/322,220, entitled “Method of and System for Malicious Software Detection Using Critical Address Space Protection,” filed Jan. 29, 2009, Inventor(s): Suman Saraf et al. |
U.S. Appl. No. 12/322,321, entitled “Method of and System for Computer System Denial-of-Service Protection,” filed Jan. 29, 2009, Inventor(s): Suman Saraf et al. |
U.S. Appl. No. 12/426,859, entitled “Method of and System for Reverse Mapping Vnode Pointers,” filed Apr. 20, 2009, Inventor(s): Suman Saraf et al. |
U.S. Appl. No. 12/545,609, entitled “System and Method for Enforcing Security Policies in a Virtual Environment,” filed Aug. 21, 2009, Inventor(s): Amit Dang et al. |
U.S. Appl. No. 12/545,745, entitled “System and Method for Providing Address Protection in a Virtual Environment,” filed Aug. 21, 2009, Inventor(s): Preet Mohinder. |
Eli M. Dow, et al., “The Xen Hypervisor,” INFORMIT, dated Apr. 10, 2008, http://www.informit.com/articles/printerfriendly.aspx?p=1187966, printed Aug. 11, 2009 (13 pages). |
“Xen Architecture Overview,” Xen, dated Feb. 13, 2008, Version 1.2, http://wiki.xensource.com/xenwiki/XenArchitecture?action=AttachFile&do=get&target=Xen+architecture—Q1+2008.pdf, printed Aug. 18, 2009 (9 pages). |
U.S. Appl. No. 12/615,521, entitled “System and Method for Preventing Data Loss Using Virtual Machine Wrapped Applications,” filed Nov. 10, 2009, Inventor(s): Sonali Agarwal, et al. |
Desktop Management and Control, Website: http://www.vmware.com/solutions/desktop/, printed Oct. 12, 2009, 1 page. |
Secure Mobile Computing, Website: http://www.vmware.com/solutions/desktop/mobile.html, printed Oct. 12, 2009, 2 pages. |
U.S. Appl. No. 12/636,414, entitled “System and Method for Managing Virtual Machine Configurations,” filed Dec. 11, 2009, Inventor(s): Harvinder Singh Sawhney, et al. |
U.S. Appl. No. 12/839,856, entitled “Containment of Network Communication,” filed Jul. 20, 2010, Inventor(s) E. John Sebes, et al. |
U.S. Appl. No. 12/844,892, entitled “System and Method for Protecting Computer Networks Against Malicious Software,” filed Jul. 28, 2010, Inventor(s) Rishi Bhargava, et al. |
“Apache Hadoop Project,” http://hadoop.apache.org/, retrieved and printed Jan. 26, 2011, 3 pages. |
“Cbl, composite blocking list,” http://cbl.abuseat.org, retrieved and printed Jan. 26, 2011, 8 pages. |
A. Pitsillidis, K. Levchenko, C. Kreibich, C. Kanich, G.M. Voelker, V. Pason, N. Weaver, and S. Savage, “Botnet Judo: Fighting Spam with Itself,” in Proceedings of the 17th Annual Network and Distributed System Security Symposium (NDSS'10), Feb. 2010, 19 pages. |
A. Ramachandran, N. Feamster, and D. Dagon, “Revealing botnet membership using DNSBL counter-intelligence,” in Proceedings of the 2nd USENIX Steps to Reducing Unwanted Traffic on the Internet, 2006, 6 pages. |
A. Ramachandran, N. Feamster, and S. Vempala, “Filtering Spam with Behavioral Blacklisting,” in Proceedings of ACM Conference on Computer Communications Security, 2007, 10 pages. |
B. Stone-Gross, M. Cova, L. Cavallor, B. Gilbert, M. Szydlowski, R. Kemmerer, C. Kruegel, and G. Vigna, “Your Botnet is My Botnet: Analysis of a Botnet Takeover,” in Proceedings of the 16th ACM Conference on Computer and Communicatinos Security, 2009, 13 pages. |
C. Kanich, C. Kreibich, K. Levchenko, B. Enright, G.M. Voelker, P. Paxson, and S. Savage, “Spamalytics: An Empirical Analysis of Spam Marketing Conversion,” in Proceedings of the 15th ACM conference on Computer and Communications Security, 2008, 12 pages. |
C.J. Burges, “A Tutorial on Support Vector Machines for Pattern Recognition,” in Journal of Data Mining and Knowledge Discovery, 1998, 43 pages. |
E-Mail Spamming Botnets: Signatures and Characteristics, Posted Sep. 22, 2008, http://www.protofilter.com/blog/email-spam-botnets-signatures.html, retrieved and printed Feb. 2, 2011, 4 pages. |
G. Gu, J. Zhang, and W. Lee, “BotSniffer: Detecting Botnet Command and Control Channels in Network Traffic,” in Proceedings of the 15th Annual Network and Distributed System Security Symposium (NDSS'08), Feb. 2008, 24 pages. |
G. Gu, P. Porras, V. Yegneswaran, M. Fong, and W. Lee, “BotHunter: Detecting Malware Infection Through IDS-Driven Dialog Correlation,” in Proceedings of the 16th USNIX Security Symposium, 2007, 34 pages. |
G. Gu, R. Perdisci, J. Zhang, and W. Lee, “BotMiner: Clustering Analysis of Network Traffic for Protocol and Structure-Independent Botnet Detection,” in Proceedings of the 17th USENIX Security Symposium, 2008, 15 pages. |
I. Jolliffe, “Principal Component Analysis,” in Springer Series in Statistics, Statistical Theory and Methods, 2nd ed.), 2002, 518 pages. |
J. Dean and S. Ghemawat, “MapRduce: Simplified Data Processing on Large Clusters,” in Proceedings of Sixth Symposium on Operating System Design and Implementation, OSDI, 2004, 13 pages. |
J. Goebel and T. Holz, “Rishi: Identify Bot Contaminated Hosts by IRC Nickname Evaluation,” in Proceedings of the USENIX HotBots, 2007, 12 pages. |
J.B. Grizzard, V. Sharma, C. Nunnery, B.B. Kang, and D. Dagon, “Peer-to-Peer Botnets: Overview and Case Study,” in Proceedings of the 1st Workshop on Hot Topics in Understanding Botnets, Apr. 2007, 14 pages. |
J.P. John, A. Moshchuk, S.D. Gribble, and A. Krishnamurthy, “Studying Spamming Botnets Using Botlab,” in Proceedings of the 6th USENIX Symposium on Networked Systems Design and Implementation, 2009, 16 pages. |
K. Li, Z. Zhong, and L. Ramaswamy, “Privacy-Aware Collaborative Spam Filtering,” in Journal of IEEE Transactions on Parallel and Distributed Systems, vol. 29, No. 5, May 2009, pp. 725-739. |
L. Zhuang, J. Dunagan, D.R. Simon, H.J. Wang, and J.D. Tygar, “Characterizing botnets from email spam records,” in Proceedings of the 1st Usenix Workshop on Large-Scale Exploits and Emergent Threats), 2008, 18 pages. |
M. Frigo and S.G. Johnson, “The Design and Implementation of FFTW3,” in Proceedings of the IEEE 93(2), Invited paper, Special Issue on Program Generation, Optimization, and Platform Adaptation, 2005, 16 pages. |
R. Perdisci, I. Corona, D. Dagon, and W. Lee, “Detecting Malicious Flux Service Networks through Passive Analysis of Recursive DNS Traces,” in Proceedings of the 25th Annual Computer Security Applications Conference (ACSAC 2009), Dec. 2009, 10 pages. |
X. Jiang, D. Xu, and Y.-M. Wang, “Collapser: A VM-Based Honeyfarm and Reverse Honeyfarm Architecture for Network Attack Capture and Detention,” in Journal of Parallel and Distributed Computing, Special Issue on Security In Grid and Distributed Systems, 2006, 16 pages. |
Y. Tang, S. Krasser, P. Judge, and Y.-Q. Zhang, “Fast and Effective Spam Sender Detection with Granular SVM on Highly Imbalanced Mail Server Behavior Data,” in Proceedings of 2nd International Conference on Collaborative Computing: Networking, Applications and Worksharing (CollaborativeCom), Nov. 2006, 6 pages. |
Y. Zhao, Y. Xie, F. Yu, Q. Ke, Y. Yu, Y. Chen, and E. Gillum, “BotGraph: Large Scale Spamming Botnet Detection,” in Proceedings of the 6th USENIX Symposium on Networked Systems Design and Implementation, 2009, 26 pages. |
Yinglian Xie, Fang Yu, Kannan Achan, Rina Panigraphy, Geoff Hulten, and Ivan Osipkov, “Spamming Botnets: Signatures and Characteristics,” SIGCOMM '08, Aug. 17, 22, 2008, http://ccr.sigcomm.org/online/files/p171-xie.pdf, pp. 171-182. |
Z. Li, A. Goyal, Y. Chen, and P. Paxson, “Automating Analysis of Large-Scale Botnet probing Events,” in Proceedings of ACM Symposium on Information, Computer and Communications Security (ASIACCS)), 2009, 12 pages. |
Barrantes et al., “Randomized Instruction Set Emulation to Dispurt Binary Code Injection Attacks,” Oct. 27-31, 2003, ACM, pp. 281-289. |
Check Point Software Technologies Ltd.: “ZoneAlarm Security Software User Guide Version 9”, Aug. 24, 2009, XP002634548, 259 pages, retrieved from Internet: URL:http://download.zonealarm.com/bin/media/pdf/zaclient91—user—manual.pdf. |
Gaurav et al., “Countering Code-Injection Attacks with Instruction-Set Randomization,” Oct. 27-31, 2003, ACM, pp. 272-280. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority (1 page), International Search Report (4 pages), and Written Opinion (3 pages), mailed Mar. 2, 2011, International Application No. PCT/US2010/055520. |
Tal Garfinkel, et al., “Terra: A Virtual Machine-Based Platform for Trusted Computing,” XP-002340992, SOSP'03, Oct. 19-22, 2003, 14 pages. |
U.S. Appl. No. 12/880,125, entitled “System and Method for Clustering Host Inventories,” filed Sep. 12, 2010, Inventor(s) Rishi Bhargava, et al. |
U.S. Appl. No. 12/903,993, entitled “Method and System for Containment of Usage of Language Interfaces,” filed Oct. 13, 2010, Inventor(s) Rosen Sharma, et al. |
U.S. Appl. No. 12/946,344, entitled “Method and System for Containment of Usage of Language Interfaces,” filed Nov. 15, 2010, Inventor(s) Rosen Sharma, et al. |
U.S. Appl. No. 13/012,138, entitled “System and Method for Selectively Grouping and Managing Program Files,” filed Jan. 24, 2011, Inventor(s) Rishi Bhargava, et al. |
U.S. Appl. No. 13/037,988, entitled “System and Method for Botnet Detection by Comprehensive Email Behavioral Analysis,” filed Mar. 1, 2011, Inventor(s) Sven Krasser, et al. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration (1 page), International Search Report (6 pages), and Written Opinion of the International Searching Authority (10 pages) for International Application No. PCT/US2011/020677 mailed Jul. 22, 2011. |
Notification of Transmittal of the International Search Report and Written Opinion of the International Searching Authority, or the Declaration (1 page), International Search Report (3 pages), and Written Opinion of the International Search Authority (6 pages) for International Application No. PCT/US2011/024869 mailed Jul. 14, 2011. |
IA-32 Intel® Architecture Software Developer's Manual, vol. 3B; Jun. 2006; pp. 13, 15, 22 and 145-146. |
Notification of International Preliminary Report on Patentability and Written Opinion mailed May 24, 2012 for International Application No. PCT/US2010/055520, 5 pages. |
Sailer et al., sHype: Secure Hypervisor Approach to Trusted Virtualized Systems, IBM research Report, Feb. 2, 2005, 13 pages. |
U.S. Appl. No. 13/558,181, entitled “Method and Apparatus for Process Enforced Configuration Management,” filed Jul. 25, 2012, Inventor(s) Rishi Bhargava et al. |
U.S. Appl. No. 13/558,227, entitled “Method and Apparatus for Process Enforced Configuration Management,” filed Jul. 25, 2012, Inventor(s) Rishi Bhargava et al. |
U.S. Appl. No. 13/558,277, entitled “Method and Apparatus for Process Enforced Configuration Management,” filed Jul. 25, 2012, Inventor(s) Rishi Bhargava et al. |
“What's New: McAfee VirusScan Enterprise, 8.8,” copyright 2010, retrieved on Nov. 23, 2012 at https://kc.mcafee.com/resources/sites/MCAFEE/content/live/PRODUCT—DOCUMENTATION/22000/PD22973/en—US/VSE%208.8%20-%20What's%20New.pdf, 4 pages. |
“McAfee Management for Optimized Virtual Environments,” copyright 2012, retrieved on Nov. 26, 2012 at AntiVirushttp://www.mcafee.com/us/resources/data-sheets/ds-move-anti-virus.pdf, 2 pages. |
Rivest, R., “The MD5 Message-Digest Algorithm”, RFC 1321, Apr. 1992, retrieved on Dec. 14, 2012 from http://www.ietf.org/rfc/rfc1321.txt, 21 pages. |
Hinden, R. and B. Haberman, “Unique Local IPv6 Unicast Addresses”, RFC 4193, Oct. 2005, retrieved on Nov. 20, 2012 from http://tools.ietf.org/pdf/rfc4193.pdf, 17 pages. |
“Secure Hash Standard (SHS)”, Federal Information Processing Standards Publication, FIPS PUB 180-4, Mar. 2012, retrieved on Dec. 14, 2012 from http://csrc.nist.gov/publications/fips/fips180-4/fips-180-4.pdf, 35 pages. |
U.S. Appl. No. 13/728,705, filed Dec. 27, 2012, entitled “Herd Based Scan Avoidance System in a Network Environment,” Inventor(s) Venkata Ramanan, et al. |
An Analysis of Address Space Layout Randomization on Windows Vista™, Symantec Advanced Threat Research, copyright 2007 Symantec Corporation, available at http://www.symantec.com/avcenter/reference/Address—Space—Layout—Randomization.pdf, 19 pages. |
Bhatkar, et al., “Efficient Techniques for Comprehensive Protection from Memory Error Exploits,” USENIX Association, 14th USENIX Security Symposium, Aug. 1-5, 2005, Baltimore, MD, 16 pages. |
Dewan, et al., “A Hypervisor-Based System for Protecting Software Runtime Memory and Persistent Storage,” Spring Simulation Multiconference 2008, Apr. 14-17, 2008, Ottawa, Canada, (available at website: www.vodun.org/papers/2008—secure—locker—submit—v1-1.pdf, printed Oct. 11, 2011), 8 pages. |
Shacham, et al., “On the Effectiveness of Address-Space Randomization,” CCS'04, Oct. 25-29, 2004, Washington, D.C., Copyright 2004, 10 pages. |
International Search Report and Written Opinion mailed Dec. 14, 2012 for International Application No. 04796-1087WO, 9 pages. |
International Preliminary Report on Patentability and Written Opinion issued Jan. 29, 2013 for International Application No. PCT/US2011/020677 (9 pages). |
International Preliminary Report on Patentability and Written Opinion issued Jan. 29, 2013 for International Application No. PCT/US2011/024869 (6 pages). |
USPTO Jun. 5, 2013 Notice of Allowance from U.S. Appl. No. 11/437,317. |
USPTO Jun. 10, 2013 Notice of Allowance from U.S. Appl. No. 12/976,159. |
USPTO Aug. 5, 2013 Notice of Allowance from U.S. Appl. No. 12/903,993. |
USPTO Aug. 13, 2013 Notice of Allowance from U.S. Appl. No. 12/946,081. |
USPTO Aug. 9, 2013 Office Action from U.S. Appl. No. 12/946,344. |
Datagram Transport Layer Security Request for Comments 4347, E. Rescorla, et al., Stanford University, Apr. 2006, retrieved and printed on Oct. 17, 2011 from http://tools.ietf.org/pdf/rfc4347.pdf, 26 pages. |
Internet Control Message Protocol Request for Comments 792, J. Postel, ISI, Sep. 1981, retrieved and printed on Oct. 17, 2011 from http://tools.ietf.org/html/rfc792, 22 pages. |
Mathew J. Schwartz, “Palo Alto Introduces Security for Cloud, Mobile Users,” retrieved Feb. 9, 2011 from http://www.informationweek.com/news/security/perimeter/showArticle.jhtml?articleID-22, 4 pages. |
Requirements for IV Version 4 Routers Request for Comments 1812, F. Baker, Cisco Systems, Jun. 1995, retrieved and printed on Oct. 17, 2011 from http://tools.ietf.org/pdf/rfc1812.pdf, 176 pages. |
The Keyed-Hash Message Authentication Code (HMAC), FIPS PUB 198, Issued Mar. 6, 2002, Federal Information Processing Standards Publication, retrieved and printed on Oct. 17, 2011 from http://csrc.nist.gov/publications/fips/fips198/fips-198a.pdf, 20 pages. |
Zhen Chen et al., “Application Level Network Access Control System Based on TNC Architecture for Enterprise Network,” In: Wireless communications Networking and Information Security (WCNIS), 2010 IEEE International Conference, Jun. 25-27, 2010 (5 pages). |
U.S. Appl. No. 13/032,851, filed Feb. 23, 2011, entitled “System and Method for Interlocking a Host and a Gateway,” Inventors: Geoffrey Howard Cooper, et al. |
USPTO Dec. 24, 2012 Nonfinal Office Action from U.S. Appl. No. 13/032,851. |
USPTO Mar. 25, 2013 Response to Dec. 24, 2012 Nonfinal Office Action from U.S. Appl. No. 13/032,851. |
USPTO Jul. 16, 2013 Final Office Action from U.S. Appl. No. 13/032,851. |
International Search Report and Written Opinion, International Application No. PCT/US2012/026169, mailed Jun. 18, 2012, 11 pages. |
U.S. Appl. No. 13/275,249, filed Oct. 17, 2011, entitled “System and Method for Redirected Firewall Discovery in a Network Environment,” Inventors: Geoffrey Cooper, et al. |
USPTO Feb. 28, 2013 Nonfinal Office Action from U.S. Appl. No. 13/275,249. |
USPTO May 13, 2013 Response to Feb. 28, 2013 Nonfinal Office Action from U.S. Appl. No. 13/275,249. |
International Search Report and Written Opinion, International Application No. PCT/US2012/057312, mailed Jan. 31, 2013, 10 pages. |
U.S. Appl. No. 13/275,196, filed Oct. 17, 2011, entitled “System and Method for Host-Initiated Firewall Discovery in a Network Environment,” Inventors: Geoffrey Cooper, et al. |
USPTO Mar. 1, 2013 Nonfinal Office Action from U.S. Appl. No. 13/275,196. |
USPTO Jun. 3, 2013 Response to Mar. 1, 2013 Nonfinal Office Action from U.S. Appl. No. 13/275,196. |
International Search Report and Written Opinion, International Application No. PCT/US2012/057153, mailed Dec. 26, 2012, 8 pages. |
U.S. Appl. No. 13/437,900, filed Apr. 2, 2012, entitled “System and Method for Interlocking a Host and a Gateway,” Inventors: Geoffrey Howard Cooper, et al. |
USPTO Mar. 1, 2013 Nonfinal Office Action from U.S. Appl. No. 13/437,900. |
USPTO Jun. 3, 2013 Response to Mar. 1, 2013 Nonfinal Office Action from U.S. Appl. No. 13/437,900. |
Office Action received for U.S. Appl. No. 12/844,892, mailed on Jan. 17, 2013, 29 pages. |
Office Action received for U.S. Appl. No. 12/844,892, mailed on Sep. 06, 2012, 34 pages. |
Response to Office Action received for U.S. Appl. No. 12/844,892, filed on Dec. 6, 2012, 34 pages. |
Kim, et al., “A load cluster management system using SNMP and web”, May 2002, pp. 367-378 available at: http://onlinelibrary.wiley.com/doi/10.1002/nem.453/pdf. |
Papadopoulos, et al., “NPACI Rocks: tools and techniques for easily deploying manageable Linux clusters”, Aug. 2002, pp. 707-725. |
Pruett, et al., “BiadeCenter systems management software”, IBM J. Res. & Dev., vol. 49, No. 6 Nov. 2005, pp. 963-975. |
Staub, et al., “Secure Remote Management and Software Distribution for Wireless Mesh Networks”, Sep. 2007, pp. 1-8. |
USPTO Feb. 24, 2014 Notice of Allowance from U.S. Appl. No. 13/629,765, 8 pages. |
USPTO Mar. 24, 2014 Notice of Allowance from U.S. Appl. No. 13/275,196, 9 pages. |
International Search Report and Written Opinion, International Application No. PCT/US2013/071327, mailed Mar. 7, 2014, 12 pages. |
USPTO Apr. 15, 2014 Notice of Allowance from U.S. Appl. No. 12/844,892, 9 pages. |
U.S. Appl. No. 14/257,770, entitled “Enforcing Alignment of Approved Changes and Deployed Changes in the Software Change Life-Cycle,” filed Apr. 21, 2014, Inventors: Rahul Roy-Chowdhury et al., 56 pages. |
International Preliminary Report on Patentability in International Application No. PCT/US2012/057312, mailed Apr. 22, 2014, 5 pages. |
International Preliminary Report on Patentability in International Application No. PCT/US2012/057153, mailed Apr. 22, 2014, 4 pages. |
U.S. Appl. No. 14/263,164, entitled “System and Method for Redirected Firewall Discovery in a Network Environment,” filed Apr. 28, 2014, Inventors: Geoffrey Cooper et al., 38 pages. |
USPTO Sep. 13, 2013 Final Office Action from U.S. Appl. No. 13/275,249. |
Narten et al., RFC 4861, “Neighbor Discovery for IP version 6 (IPv6)”, Sep. 2007, retrieved from http://tools.ietf.org/html/rfc4861, 194 pages. |
International Preliminary Report on Patentability, International Application No. PCT/US2012/026169, mailed Aug. 27, 2013, 8 pages. |
USPTO Oct. 2, 2013 Final Office Action from U.S. Appl. No. 13/275,196. |
USPTO Oct. 4, 2013 Nonfinal Office Action from U.S. Appl. No. 12/844,892. |
USPTO Oct. 25, 2013 Nonfinal Office Action from U.S. Appl. No. 12/844,964. |
U.S. Appl. No. 14/045,208, filed Oct. 3, 2013, entitled “Execution Environment File Inventory,” Inventors: Rishi Bhargava, et al. |
PCT Application Serial No. PCT/US13/66690, filed Oct. 24, 2013, entitled “Agent Assisted Malicious Application Blocking in a Network Environment,”, 67 pages. |
Patent Examination Report No. 1, Australian Application No. 2011283160, mailed Oct. 30, 2013. |
USPTO Sep. 27, 2013, Notice of Allowance from U.S. Appl. No. 13/437,900. |
PCT Application Serial No. PCT/US13/71327, filed Nov. 21, 2013, entitled “Herd Based Scan Avoidance System in a Network Environment,”, 46 pages. |
USPTO Dec. 4, 2013 Nonfinal Office Action from U.S. Appl. No. 13/032,851. |
U.S. Appl. No. 14/127,395, entitled “Agent Assisted Malicious Application Blocking in a Network Environment,” filed Dec. 18, 2013, Inventors: Chandan CP et al. |
USPTO Dec. 26, 2013 Notice of Allowance from U.S. Appl. No. 13/275,249. |
USPTO Dec. 16, 2013 Notice of Allowance from U.S. Appl. No. 13/275,196. |
USPTO Jan. 13, 2014 Notice of Allowance from U.S. Appl. No. 13/437,900. |
Patent Examination Report No. 1, Australian Application No. 2011283164, mailed Jan. 14, 2014. |
USPTO Dec. 30, 2013 Final Office Action from U.S. Appl. No. 13/629,765. |
USPTO Jun. 4, 2014 Notice of Allowance from U.S. Appl. No. 13/032,851, 16 pages. |
USPTO Jun. 4, 2014 Nonfinal Office Action from U.S. Appl. No. 13/728,705, 16 pages. |
Jun. 2, 2014 Office Action in Korean Patent Appln. No. 2013-7022241, [English translation], 6 pages. |
USPTO Aug. 11, 2014 Notice of Allowance from U.S. Appl. No. 12/844,892, 8 pages. |
Aug. 12, 2014 Office Action in Japanese Patent Application No. 2013-555531, English translation, 3 pages. |
USPTO Oct. 27, 2014 Notice of Allowance from U.S. Appl. No. 13/728,705, 25 pages. |
Number | Date | Country | |
---|---|---|---|
20120030750 A1 | Feb 2012 | US |