A network security system comprises a plurality of sensors, a management server, and a data collection module. The plurality of sensors receive first data associated with potential attacks on the system. The manager server is coupled to at least one sensor and correlates at least a portion of the first data to detect potential attacks on the system. The data collection module is coupled to the manager server and generates at least one request for second data based upon at least one of the first data and the correlated data. The data collection module communicates the request to at least one source different from the plurality of sensors.
|
11. A method for providing network security, comprising:
receiving first data at a sensor, the first data associated with potential attacks on a network security system;
correlating by a manager server at least a portion of the first data to detect potential attacks on the system based on a correlation rule set;
communicating by the manager server a query comprising the first data and the correlated data, the correlated data being based at least in part on the correlation of at least a portion of the first data;
receiving the query from the manager server at a data collection module;
generating by the data collection module at least one request for second data based upon the received query;
communicating by the data collection module the at least one request to at least one source different from the sensor, wherein the at least one source is a server that translates ip addresses;
correlating the second data received from the server that translates ip addresses with at least a portion of the first data received by the plurality of sensors; and
generating a relationship score indicating a likelihood that the first data is related to a previous potential attack based on the correlated second data and event history in the archive database;
the first data associated with potential attacks on the network security system being communicated from the sensor to the manager server without passing through the data collection module.
16. A data collection module for use in a network security system, the data collection module comprising:
one or more processors;
a state module operable to:
receive a query from a manager server, the query comprising a first data associated with potential attacks on a network security system received at a sensor and correlated data, the correlated data generated by the manager server from at least a portion of the first data based on a correlation rule set in order to detect potential attacks on the system; and
maintain state information for a plurality of events, wherein at least one event is associated with potential attacks on a network security system;
a data collection engine coupled to the state module and an archive database, the data collection module, for at least one event, operable to:
communicate a request for data to a data source that translates ip addresses; and
receive data from the data source that translates ip addresses in response to the request; and
a correlation engine operable to correlate the received data from the data source that translates ip addresses with the state information to detect potential attacks on the system, and generate a relationship score indicating a likelihood that the first data is related to a previous potential attack based on the correlated received data and event history in the archive database;
the first data associated with potential attacks on the network security system being communicated from the sensor to the manager server without passing through the data collection module.
1. A network security system, comprising:
a plurality of sensors operable to receive first data associated with potential attacks on a network security system;
a manager server coupled to at least one of the plurality of sensors and comprising a first processor, the manager server operable to:
correlate at least a portion of the first data based on a correlation rule set to detect potential attacks on the system; and
communicate a query comprising the first data and the correlated data, the correlated data being based at least in part on the correlation of at least a portion of the first data; and
a data collection module coupled to the manager server and an archive database, the data collection module comprising a second processor, the data collection module operable to:
receive the query from the manager server;
generate at least one request for second data based upon the received query;
communicate the at least one request to at least one source different from the plurality of sensors, wherein the at least one source is a server that translates ip addresses;
correlate second data received from the server that translates ip addresses with at least a portion of the first data received by the plurality of sensors; and
generate a relationship score indicating a likelihood that the first data is related to a previous potential attack based on the correlated second data and event history in the archive database;
the first data associated with potential attacks on the network security system being communicated from the plurality of sensors to the manager server without passing through the data collection module.
2. The system of
3. The system of
4. The system of
5. The system of
6. The system of
7. The system of
8. The system of
a geographic location server that translates between ip addresses and geographic locations.
9. The system of
10. The system of
12. The method of
13. The method of
receiving the second data in response to the at least one request; and
in response to receiving the second data, generating another request to at least one source different from the sensor.
14. The method of
15. The method of
a geographic location server that translates between ip addresses and geographic locations; and
an internet directory server that translates between domain names and ip addresses.
17. The data collection module of
at least one event is associated with data received from a sensor; and
the data source is different from the sensor.
18. The data collection module of
19. The data collection module of
data that has been requested;
data that has been received in response to a request;
data that is yet to be requested; and
correlated data.
20. The data collection module of
a geographic location server that translates between ip addresses and geographic locations; and
an internet directory server that translates between domain names and ip addresses.
|
This invention relates to intrusion detection systems and, more specifically, to a system for active data collection in a network security system.
Intrusion detection systems are used by an enterprise to detect and identify unauthorized or unwanted use (commonly called an attack) of the enterprise's computer network, which normally comprises a large number of nodes and network operations centers. In general, these enterprise intrusion detection systems receive data using sensors or other intrusion detection devices. The system then scans the incoming data for specific patterns in network traffic, audit trails, and other data sources to detect malicious activity. The data that is received in the input stream is passively gathered. In other words, traditional intrusion detection systems are reactive in the sense that they wait for data to be sent to it before performing any sort of correlation or other data processing. As a result, certain additional data that may be useful in detecting malicious activity may not be considered by the system.
In accordance with the present invention, the disadvantages and problems associated with traditional enterprise intrusion detection systems have been substantially reduced or eliminated.
In one embodiment of the present invention, a network security system comprises a plurality of sensors, a management server, and a data collection module. The plurality of sensors receive first data associated with potential attacks on the system. The management server is coupled to at least one sensor and correlates at least a portion of the first data to detect potential attacks on the system. The data collection module is coupled to the manager server and generates at least one request for second data based upon at least one of the first data and the correlated data. The data collection module communicates the request to at least one source different from the plurality of sensors.
In another embodiment of the present invention, a method for providing network security comprises receiving first data at a sensor, the first data associated with potential attacks on the system. The method continues by correlating at least a portion of the first data to detect potential attacks on the system. The method continues by generating at least one request for second data based upon at least one of the first data and the correlated data. The method concludes by communicating the request to at least one source different from the sensor.
The invention has several important technical advantages. Various embodiments of the invention may have none, some, or all of these advantages. One advantage of the present invention is that it performs active data collection and correlation using a data collection module and data sources. By using active data collection techniques, the system considers specific data that is useful in detecting malicious activity but that was not received by sensors in the normal course of operation. As a result, the system can perform enhanced correlations of data that may not otherwise have been performed. The system is therefore better equipped to detect and resolve attacks on the enterprise.
The data collection module is disconnected from the normal event flow and the correlated event flow. As a result, the active data collection activities of the system do not impair the normal processing of data by sensors, manager servers, or global manager servers.
Other technical advantages of the present invention will be readily apparent to one skilled in the art from the description and the appended claims.
For a more complete understanding of the present invention and its advantages, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
The “enterprise” may comprise any business, government, organization, or other entity that has multiple network channels or ports to a network 100. Network 100 may include any suitable portions of an external network and/or an internal network. In addition, the business enterprise may further include links to portions of an internal network. In this regard, intrusion detection system 10 monitors network communications on internal links as well. For example, a business enterprise may include three ports for external network communications including email, internet, and dialup. In this example, intrusion detection system 10 monitors network communications on the three external ports. Based upon data received in these input streams and data actively collected by module 60, system 10 attempts to detect, locate, or block an attack on the business. An “attack” may be any malicious, destructive, or suspicious activity communicated from a source external and/or internal to the portion of the enterprise protected by system 10. Attacks may include viruses, Trojan horses, worms, or any other piece of code or data that represents at least a portion of an unwanted attempt to access the protected portion of the enterprise.
Internal network 80 may include one or more intranets, local area networks (LANs), metropolitan area networks (MANs), wide area networks (WANs), or any other suitable enterprise network. Network 80 may, for example, communicate Internet Protocol (IP) packets, frame relay frames, Asynchronous Transfer Mode (ATM) cells, and/or other suitable messages between network addresses. According to particular embodiments, messages between the levels may be in one or more formats including Intrusion Detection Message Exchange Format (IDMEF), binary format, and/or any other appropriate format.
Network 100 represents any network not protected by intrusion detection system 10. Accordingly, network 100 communicably couples system 10 with other computer systems. Network 100 may, for example, communicate Internet Protocol (EP) packets, frame relay frames, Asynchronous Transfer Mode (ATM) cells, and/or other suitable information between network addresses. Network 100 may include one or more intranets, local area networks (LANs), metropolitan area networks (MANs), wide area networks (WANs), all or a portion of the Internet, and/or any other communication system or systems at one or more locations. An external client system (not shown) may be any computer, enterprise or non-enterprise, which is trying to access the portion of internal network 80 protected by intrusion detection system 10. As used in this document, the term “computer” is intended to encompass a personal computer, server, mainframe, terminal, workstation, network computer, kiosk, wireless data port, wireless telephone, personal digital assistant (PDA), one or more processors within these or other devices, or any other suitable processing device.
Each sensor 20 is located at a network port that receives TCP/IP packets or other similar network communications from network 100. Generally, sensor 20 processes the raw data to detect the presence of an attack and outputs at least the raw data and, when appropriate, a corresponding alert message. In certain embodiments, sensor 20 may also generate messages, such as a packet flow, based on the raw data received from network 100. All of the communications between one or more sensors 20 and one or more manager servers 30 may be referred to as an event flow.
Sensor 20 may use any suitable detection technique to process incoming data and output the appropriate messages. For example, sensor 20 may use algorithms, signatures, scripts, or any suitable detection or comparison technique to process packet headers, packet payloads, and/or any other incoming data. Sensor 20 could include any suitable combination of hardware, software, or firmware to receive data from sources via network 100, process the raw network data, and communicate results to higher levels. For example, sensor 20 may comprise a computer, server, lower-level intrusion detection system, firewall, or any module written in any appropriate computer language such as, for example, C, C++, Java, Perl, and others. It will be understood that while sensor 20 is illustrated as a single multi-tasked module, the features and functionality performed by this engine may be performed by multiple modules such as for example, a sensor module and a packet flow generation module. Additionally, to help ensure that each port is properly monitored, each sensor 20 may be associated with a redundant slave sensor which is operable to assume substantially all of the functionality of the sensor 20 in the event of any failure of sensor 20.
Manager server 30 represents any hardware or software module that controls or monitors one or more servant nodes, such as a sensor 20. In one example, each manager server 30 includes a correlation engine 110 and a correlation ruleset 120 for receiving and correlating data from sensors 20 and/or data collection module 60. Generally, through correlating and aggregating lower-level communications, manager server 30 is capable of detecting an attack occurring within the enterprise and dynamically responding to such a threat.
According to certain embodiments, manager server 30 comprises a general-purpose personal computer (PC), a Macintosh, a workstation, a Unix-based computer, a server computer, or any other suitable processing device. Additionally, to make system 10 more robust, each manager server 30 may be associated with a redundant manager server which is operable to assume substantially all of the functionality of manager server 30 in the event of a failure of the associated manager server 30. Although
Global server 40 may comprise a general-purpose personal computer (PC), a workstation, a Unix-based computer, a server computer, or any other suitable processing device. Although
Global server 40 may include an archive database 130 to store the raw archival data collected from various nodes of system 10 for later processing, retrieval, or searches. Archive database 130 may include any memory or database module and may take the form of volatile or non-volatile memory comprising, without limitation, magnetic media, optical media, random access memory (RAM), read-only memory (ROM), removable media, or any other suitable local or remote memory component. In one embodiment, archive database 130 comprises stored IP information such as, for example, TCPDump data corresponding to each packet flow. Archive database 130 may include any other data such as, for example, historical operator commands or response messages previously communicated to lower nodes. Global server 40 may include a global correlation engine 140 that is further operable to process information in archive database 130 to detect the presence of a substantially long-term or multi-staged attack that had previously gone undetected by sensors 20 and manager servers 30. Although
Global server 40 may further comprise a filtering ruleset 150. Filtering ruleset 150 allows system 10 to reduce the analyst's workload through filtering the information communicated to console 50. Ruleset 150 comprises instructions, algorithms, or any other directive which largely controls the information communicated to console 50. Although
Console 50 may represent any computer that may comprise input devices, output devices, mass storage media, processors, memory, or other components for receiving, processing, storing, and/or communicating information. Intrusion detection system 10 may communicate the intrusion information, such as correlated and/or filtered data, to console 50 so that a user, such as a supervisor or administrator, may view and process the intrusion information. It will be understood that there may be any number of consoles 50 used in system 10 such as, for example, one or more operator or analyst consoles 50 and a supervisor console 50. Console 50 may include a graphical user interface (GUI) 52 that tailors and filters the data presented to the user. Generally, GUI 52 provides the user of console 50 with an efficient and user-friendly presentation of data and events occurring in system 10.
Data collection module 60 comprises any suitable combination of hardware and software to perform active data collection and correlation techniques. Data collection module 60 requests and receives information from data sources 70 using one or more requests 170. The information is returned in the form of one or more responses 172. Each request 170 may be based upon a kernel of information already received within system 10, such as, for example, data associated with one or more attack events on system 10, data correlated by servers 30 and/or 40, or even one or more responses 172. Data sources 70 comprise sources of data that are either internal or external to system 10. For example, a data source 70 may comprise a geographic location server that translates between IP addresses and geographic locations. A data source 70 may also comprise an internet directory server, such as a Domain Name System (DNS) server, that translates between domain names and IP addresses. A data source 70 may also comprise a security vulnerability device, such as a scanner (e.g., Nessus), a server, or a database. Such a device may be used to launch covert gathering agents directly at an attacker.
The kernel of information used to request more information from data sources 70 may be a piece of raw data received by a manager server 30, such as, for example, the source IP address of an attacker; the time of day of a particular attack; or the port on which a sensor 20 received the raw data. The kernel of information may also be the result of a correlation of data performed by a server 30, such as, for example, the common source IP address of a series of attacks; the range of times of a series of attacks; or the common port on which a series of attacks were initiated.
An example is used to illustrate the process of generating requests 170 and receiving responses 172. It is generally difficult to correlate attacks made from open wireless networks. Users may connect to open wireless networks from the safety of a roadside vehicle and attack or probe a remote site. After attacking, they can simply drive to another open network and attack with a different tool or probe to that network to gain more information about it. The explosion of WI-FI technology in home and office use makes it relatively easy to find and penetrate these networks as “free” connections to the internet. This attack method allows the attacker to gather data on a remote network very quickly in seemingly disconnected intrusion attempts. Since the attacks come from different network addresses and many times from different service providers at different times, there is no clear correlation to tie them together other than geographic location.
After receiving one of these attacks, manager server 30 may send a query 204 to data collection module 60 to collect and correlate additional information about one or more of the attacks. For example, data collection module 60 may try to discover the geographical location of the attacks. A “trace route” to the attacking FP address and a DNS query on the attacking IP address may result in the determination that the attack came from Malibu, Calif., or nearby. In particular, data collection module 60 may generate a request 170 of a geographic location server using one or more known IP addresses in order to determine the geographic location of the attack. The geographic location server may indicate the geographic location information as one or more responses 172 to data collection module 60. Another request 170 may be initiated to determine whether other attacks have been made in this area in the last several days. No results may be found.
In an hour, another attack may be detected and another query 204 may be sent to the data collection module 60. The geographic location of this attack may also be determined to be Malibu, Calif., even though the service provider and the IP address are in every other way unrelated to the first attempt. This time, when another request 170 is made to identify other attacks from this geographical area, the first attack is found, and the two are correlated by data collection module 60. This additional correlation information 206 is communicated to console 50, such as in the form of a relationship score. This relationship score indicates the likelihood that the two attacks are related, based on previous experiences or possibly through the use of a Bayesian network weight.
In time, as the attacker uses different networks and attacks, these attacks are added to the group of attacks from Malibu, Calif. Data collection module 60 may correlate information regarding each of these attacks. When a threshold number of such attacks has been identified, this information may also be brought to the attention of the operator in the form of correlation information 206, and the intrusion attempts are plotted on a map with times of attack noted. The operator at console 50 may recognize a pattern and contact local authorities in Malibu, Calif. with information that could lead to the arrest and conviction of the attacker.
Although in this case, the geographical location is the information that is actively gathered, there are several other types of information that could be requested by data collection module 60. For instance, a vulnerability scan of the attacking machine can reveal a vulnerability signature that can be correlated with other data or used to “hack back” the attacking machine. Logs requested from SQL, WEB, MAIL, and firewall servers could give an indication of other activities the attacker has been involved in. It may be that the volume of these logs is too large to be included during normal operation but can be requested under special circumstances. In the case that the attacker is directly connected to the network being attacked (for instance in the case of an “insider” attack), exhaustive information and packet logs can be requested of the switch connecting that user to the network. The number of items of data that can be requested or obtained are significant.
After responses 172 are received, data collection module 60 may perform correlation with other events, such as events stored in one or more archive databases 130, that may not up to that point have been associated with the original event. For example, after requesting DNS records from a DNS server, it may be determined that event A and event B are from source IP addresses under the same administrative control of a single company. They may be loosely or tightly associated as a result of this new information. In addition, this connection may prompt further information gathering (e.g., for instance an exhaustive list of IP addresses under the same administrative control). On the other hand, additional information may serve to weaken previous correlative work. For example, since two attacks occurred together in time it would suggest that they may be related. However, upon doing a vulnerability scan of the machines, it may become clear that one is being controlled through a well known “drone” program while the other is an attack through a dialup network commonly used for attacks, and no evidence of a similar “drone” program exists.
By actively requesting this information and considering it in further correlation, data collection module 60 increases considerably the number of attacks found and the amount of understanding of the current state of the network being monitored.
In general, event state module 250 is responsible for maintaining state information for events that are the subject of queries 204. Examples of state information maintained by event state module 250 include additional data that has been requested by data collection engine 252; additional data that has been received in response to a request 170; additional data that is yet to be requested; and correlated data. Data collection engine 252 is responsible for performing the active data collection process, including communicating requests 170 and receiving responses 172. Data collection engine 252 may initiate several data collection processes in response to one or more queries 204, or in response to one or more previous responses 172. Event state module 250 maintains state information to keep track of the various data collection processes that have been or will be initiated and/or completed. Correlation engine 254 is responsible for correlating the additional data received in a response 172 with other data, such as data stored in archive database 130, data stored in event state module 250, other data correlated by correlation engine 254, other data correlated by other correlation engines 110, or any other data within system 10.
In operation, when information about a new event or a group of events is received, in conjunction with a query 204, it is recorded in the event state module 250. Module 250 keeps track of the state of all of the current events for which additional information is being gathered. After the state information is recorded, an appropriate data collection process is invoked by data collection engine 252. For example, a DNS query process may be invoked in order to generate an appropriate request 170 from a DNS server data source 70. The DNS query process would be responsible for obtaining the information and returning that information to the state module 250 so that the new state can be computed. It may be that the information cannot be obtained or that the data collection engine 252 fails to report back. In this case, an automated timer can be implemented to recalculate a state of old requests 170 and decide what to do. For example, after a timeout, a previous request 170 may be reissued a predetermined number of times. Alternatively, or in addition, the previous request 170 may be discarded after a certain number of attempts have failed.
Data collection engine 252 may receive responses 172 that may be communicated to event state module 250. When the state information is updated with the new information gathered, the information is handed to the correlation engine 254 which operates similarly to the correlation engine 110 of manager service 30. Correlation engine 254 correlates data collected by data collection engine 252 with other data collected by engine 252, data received by sensors 20, or with the results of other data correlation to produce results. If a good decision can be made, the new correlated data 206 is sent to the appropriate console 50. On the other hand, additional information may yet be required, in which case the incident would be again given to the event state module 250 and additional information requested by data collection engine 252.
Another example may be used to illustrate the operation of data collection module 60. System 10 receives many attacks upon a specific host from a variety of sources. A query 204 is sent to the data collection module 60 to try to find a correlation between these attacks. The correlation engine 254 of the data collection module 60 first tries to determine if the geographic source of the attacks is similar. If this fails, the correlation engine 254 tries to determine if the DNS administrative contact is the same. If this fails, the correlation engine 254 queries the event history for time correlation between each pair of source IP addresses to see if they have acted in concert before. This type of querying can involve one or more requests 170 and responses 172 to collect additional information from data sources 70 that may be useful to correlation engine 254. The querying can go on until some type of correlation between the attacks is found. In that case, an appropriate action can be taken. Alternatively, the querying may go on for a period of time without leading to any correlation, at which point it may be terminated. In either case, the querying may be recorded in the event state module 250.
In another example, system 10 receives an attack from a host. The data collection module 60 determines using a local lookup that this host has previously had a “counter agent” installed on it by system 10 to monitor activity. An information request 170 is put into the queue for a list of recent network connections on that host. When the host reports in, as it does periodically, that information is given to the event state module 250. Each entry in the list is correlated with previous attackers by correlation engine 254, and it is found that more than two hosts that have attacked system 10 have had connection to this third IP address. An incident that tracks these together is created to gather evidence of this third party using intermediate machines to attack system 10. A scan is sent to the “real” attacker and its vulnerability is assessed. Appropriate action, such as a counter attack or communicating with an internet service provider can now be taken.
Therefore, there are a great variety of times when by requesting additional information, much smarter decisions of what to do can be made by correlation engines within system 10. Data collection module 60 may be used to enable this type of active information gathering.
Although the present invention has been described in detail, it should be understood that various changes, substitutions and alterations can be made hereto without departing from the scope of the invention as defined by the appended claims.
Patent | Priority | Assignee | Title |
10002250, | Jun 08 2012 | CrowdStrike, Inc. | Security agent |
10027686, | May 30 2012 | MICRO FOCUS LLC | Parameter adjustment for pattern discovery |
10050997, | Jun 30 2014 | INTUIT INC. | Method and system for secure delivery of information to computing environments |
10055247, | Apr 18 2014 | INTUIT INC. | Method and system for enabling self-monitoring virtual assets to correlate external events with characteristic patterns associated with the virtual assets |
10084815, | Nov 07 2014 | CLOUDFLARE, INC | Remediating computer security threats using distributed sensor computers |
10102082, | Jul 31 2014 | INTUIT INC. | Method and system for providing automated self-healing virtual assets |
10235677, | Dec 15 2006 | Comscore, Inc; Rentrak Corporation; Proximic, LLC | Determination and application of click quality |
10289405, | Mar 20 2014 | CrowdStrike, Inc. | Integrity assurance and rebootless updating during runtime |
10339316, | Jul 28 2015 | CrowdStrike, Inc. | Integrity assurance through early loading in the boot phase |
10360062, | Feb 03 2014 | INTUIT INC. | System and method for providing a self-monitoring, self-reporting, and self-repairing virtual asset configured for extrusion and intrusion detection and threat scoring in a cloud computing environment |
10387228, | Feb 21 2017 | CrowdStrike, Inc.; CROWDSTRIKE, INC | Symmetric bridge component for communications between kernel mode and user mode |
10397250, | Jan 21 2016 | F5 Networks, Inc | Methods for detecting remote access trojan malware and devices thereof |
10402832, | Dec 15 2006 | Comscore, Inc; Rentrak Corporation; Proximic, LLC | Network interaction correlation |
10432652, | Sep 20 2016 | F5 Networks, Inc. | Methods for detecting and mitigating malicious network behavior and devices thereof |
10476947, | Mar 02 2015 | F5 Networks, Inc | Methods for managing web applications and devices thereof |
10503627, | Oct 30 2017 | Bank of America Corporation | Robotic process automation enabled file dissection for error diagnosis and correction |
10575231, | Nov 03 2017 | Bank of America Corporation | System for connection channel adaption using robotic automation |
10581902, | Nov 30 2015 | F5 Networks, Inc. | Methods for mitigating distributed denial of service attacks and devices thereof |
10594724, | Jul 19 2017 | Cisco Technology, Inc. | Network security user interface for domain query volume time series with custom signal modifications |
10606687, | Dec 04 2017 | Bank of America Corporation | Process automation action repository and assembler |
10616280, | Oct 25 2017 | Bank of America Corporation | Network security system with cognitive engine for dynamic automation |
10659482, | Oct 25 2017 | Bank of America Corporation | Robotic process automation resource insulation system |
10740459, | Dec 28 2017 | CROWDSTRIKE, INC | Kernel- and user-level cooperative security processing |
10757133, | Feb 21 2014 | INTUIT INC. | Method and system for creating and deploying virtual assets |
10834110, | Dec 18 2015 | F5 Networks, Inc | Methods for preventing DDoS attack based on adaptive self learning of session and transport layers and devices thereof |
10853491, | Jun 08 2012 | CrowdStrike, Inc. | Security agent |
10958691, | Oct 25 2017 | Bank of America Corporation | Network security system with cognitive engine for dynamic automation |
10972954, | Nov 03 2017 | Bank of America Corporation | System for connection channel adaption using robotic automation |
11038869, | May 12 2017 | F5 Networks, Inc | Methods for managing a federated identity environment based on application availability and devices thereof |
11132279, | Oct 30 2017 | Bank of America Corporation | Robotic process automation enabled file dissection for error diagnosis and correction |
11294700, | Apr 18 2014 | INTUIT INC. | Method and system for enabling self-monitoring virtual assets to correlate external events with characteristic patterns associated with the virtual assets |
11327828, | Dec 04 2017 | Bank of America Corporation | Process automation action repository and assembler |
11340890, | Mar 20 2014 | CrowdStrike, Inc. | Integrity assurance and rebootless updating during runtime |
11349981, | Oct 30 2019 | F5, Inc. | Methods for optimizing multimedia communication and devices thereof |
11411984, | Feb 21 2014 | INTUIT INC. | Replacing a potentially threatening virtual asset |
11539740, | Feb 02 2018 | F5, INC | Methods for protecting CPU during DDoS attack and devices thereof |
11616806, | May 08 2015 | F5 Networks, Inc | Methods for protecting web based resources from D/DoS attacks and devices thereof |
11658971, | Aug 23 2010 | Amazon Technologies, Inc. | Virtual firewalls for multi-tenant distributed services |
11914720, | Jun 29 2018 | SOONCHUNHYANG UNIVERSITY INDUSTRY ACADEMY COOPERATION FOUNDATION | Method for verifying drone included in industrial internet of things system, by using petri-net modeling |
8990379, | Dec 15 2006 | Comscore, Inc; Rentrak Corporation; Proximic, LLC | Network interaction monitoring appliance |
9374385, | Nov 07 2014 | CLOUDFLARE, INC | Remediating computer security threats using distributed sensor computers |
9412111, | Dec 15 2006 | Comscore, Inc; Rentrak Corporation; Proximic, LLC | Network interaction monitoring appliance |
9459987, | Mar 31 2014 | INTUIT INC. | Method and system for comparing different versions of a cloud based application in a production environment using segregated backend systems |
9473481, | Jul 31 2014 | INTUIT INC. | Method and system for providing a virtual asset perimeter |
9501345, | Dec 23 2013 | INTUIT INC.; INTUIT INC | Method and system for creating enriched log data |
9516064, | Oct 14 2013 | INTUIT INC. | Method and system for dynamic and comprehensive vulnerability management |
9596251, | Apr 07 2014 | INTUIT INC. | Method and system for providing security aware applications |
9686301, | Feb 03 2014 | INTUIT INC. | Method and system for virtual asset assisted extrusion and intrusion detection and threat scoring in a cloud computing environment |
9712557, | Nov 07 2014 | CLOUDFLARE, INC | Remediating computer security threats using distributed sensor computers |
9742794, | May 27 2014 | INTUIT INC. | Method and apparatus for automating threat model generation and pattern identification |
9858626, | Jun 29 2012 | CrowdStrike, Inc. | Social sharing of security information in a group |
9866581, | Jun 30 2014 | INTUIT INC | Method and system for secure delivery of information to computing environments |
9900322, | Apr 30 2014 | INTUIT INC. | Method and system for providing permissions management |
9904784, | Jun 08 2012 | CrowdStrike, Inc. | Kernel-level security agent |
9923909, | Feb 03 2014 | INTUIT INC. | System and method for providing a self-monitoring, self-reporting, and self-repairing virtual asset configured for extrusion and intrusion detection and threat scoring in a cloud computing environment |
Patent | Priority | Assignee | Title |
5020411, | Mar 06 1989 | Mobile assault logistic kinetmatic engagement device | |
5341229, | Jul 14 1988 | Holographic display system | |
5432871, | Aug 04 1993 | UNIVERSAL SYSTEMS & TECHNOLOGY, INC | Systems and methods for interactive image data acquisition and compression |
5790599, | Jan 19 1989 | Redband Technologies, Inc. | Data compression system using source representation |
5805801, | Jan 09 1997 | TREND MICRO INCORPORATED | System and method for detecting and preventing security |
5991881, | Nov 08 1996 | RPX Corporation | Network surveillance system |
6226589, | Mar 12 1999 | Fujitsu Limited | System for providing guiding information for use in detecting and accessing a mobile object |
6253337, | Jul 21 1998 | Computer Associates Think, Inc | Information security analysis system |
6327550, | May 26 1998 | CA, INC | Method and apparatus for system state monitoring using pattern recognition and neural networks |
6341298, | Mar 22 1998 | HANGER SOLUTIONS, LLC | Signal equalization |
6347263, | Jul 31 1995 | AlliedSignal Inc.; AlliedSignal Inc | Aircraft terrain information system |
6404380, | Dec 21 1993 | Colorado State University Research Foundation | Method and system for tracking multiple regional objects by multi-dimensional relaxation |
6408297, | Feb 03 1999 | Fujitsu Limited | Information collecting apparatus |
6421467, | May 28 1999 | Texas Tech University | Adaptive vector quantization/quantizer |
6574378, | Jan 22 1999 | Kent Ridge Digital Labs | Method and apparatus for indexing and retrieving images using visual keywords |
6633882, | Jun 29 2000 | Microsoft Technology Licensing, LLC | Multi-dimensional database record compression utilizing optimized cluster models |
6650779, | Mar 26 1999 | Georgia Tech Research Corporation | Method and apparatus for analyzing an image to detect and identify patterns |
6665715, | Apr 03 2000 | Microsoft Technology Licensing, LLC | Method and systems for locating geographical locations of online users |
6674911, | Sep 14 1995 | N-dimensional data compression using set partitioning in hierarchical trees | |
6744396, | Jul 20 2001 | L-3 Communications Corporation | Surveillance and collision avoidance system with compound symbols |
6907430, | Oct 04 2001 | BOOZ-ALLEN HAMILTON, INC | Method and system for assessing attacks on computer networks using Bayesian networks |
6954775, | Jan 15 1999 | Cisco Technology, Inc. | Parallel intrusion detection sensors with load balancing for high speed networks |
7017186, | Jul 30 2002 | LONGHORN HD LLC | Intrusion detection system using self-organizing clusters |
7058976, | May 17 2000 | TREND MICRO INCORPORATED | Intelligent feedback loop process control system |
7100204, | Apr 05 2002 | International Business Machines Corporation | System and method for determining network users' physical locations |
7127743, | Jun 23 2000 | LOG STORM SECURITY, INC ; BLACKSTRATUS, INC | Comprehensive security structure platform for network managers |
7130611, | Nov 16 2000 | NTT DOCOMO INC | Moving status information providing method and server |
7146421, | Mar 19 2001 | FORCEPOINT FEDERAL HOLDINGS LLC; Forcepoint LLC | Handling state information in a network element cluster |
7185368, | Nov 30 2000 | Cisco Technology, Inc | Flow-based detection of network intrusions |
7251376, | Aug 29 2003 | Canadian Space Agency | Data compression engines and real-time wideband compressor for multi-dimensional data |
7324108, | Mar 12 2003 | TREND MICRO INCORPORATED | Monitoring events in a computer network |
7370358, | Sep 28 2001 | British Telecommunications public limited company | Agent-based intrusion detection system |
20020016831, | |||
20020059164, | |||
20020066034, | |||
20020078381, | |||
20020112189, | |||
20020165842, | |||
20030009699, | |||
20030023876, | |||
20030058339, | |||
20030084349, | |||
20030105976, | |||
20030145226, | |||
20030154399, | |||
20030177383, | |||
20030188189, | |||
20030200236, | |||
20030217289, | |||
20040015719, | |||
20040024855, | |||
20040025044, | |||
20040044912, | |||
20040049698, | |||
20040098623, | |||
20040103211, | |||
20040107125, | |||
20040117407, | |||
20040117654, | |||
20040133543, | |||
20040172557, | |||
20040193943, | |||
20040215977, | |||
20040260945, | |||
20040261116, | |||
20040267886, | |||
20050044406, | |||
20050047670, | |||
20050108518, | |||
20050138110, | |||
20050210532, | |||
20050222996, | |||
20050254654, | |||
20060010493, | |||
20060031934, | |||
20060037075, | |||
20060123478, | |||
20060130070, | |||
20060156401, | |||
20060209836, | |||
20060253905, | |||
20060253907, | |||
20070009160, | |||
20070107053, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jun 28 2005 | ROCKWOOD, TROY D | Raytheon Company | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 016763 | /0915 | |
Jul 06 2005 | Raytheon Company | (assignment on the face of the patent) | / | |||
May 28 2015 | Raytheon Company | RAYTHEON CYBER PRODUCTS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035774 | /0322 | |
May 28 2015 | RAYTHEON CYBER PRODUCTS, INC | Raytheon Cyber Products, LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 035806 | /0367 | |
May 29 2015 | PORT AUTHORITY TECHNOLOGIES, INC | Raytheon Company | PATENT SECURITY AGREEMENT | 035859 | /0282 | |
May 29 2015 | RAYTHEON CYBER PRODUCTS, LLC FORMERLY KNOWN AS RAYTHEON CYBER PRODUCTS, INC | Raytheon Company | PATENT SECURITY AGREEMENT | 035859 | /0282 | |
May 29 2015 | Raytheon Oakley Systems, LLC | Raytheon Company | PATENT SECURITY AGREEMENT | 035859 | /0282 | |
May 29 2015 | WEBSENSE, INC | Raytheon Company | PATENT SECURITY AGREEMENT | 035859 | /0282 | |
Jan 13 2016 | Raytheon Cyber Products, LLC | FORCEPOINT FEDERAL LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 037821 | /0818 | |
Jul 28 2017 | FORCEPOINT FEDERAL LLC | Forcepoint LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043397 | /0460 | |
Jan 08 2021 | Raytheon Company | FORCEPOINT FEDERAL LLC FKA RAYTHEON CYBER PRODUCTS, LLC, FKA RAYTHEON CYBER PRODUCTS, INC | RELEASE OF SECURITY INTEREST IN PATENTS | 055492 | /0146 | |
Jan 08 2021 | Raytheon Company | Raytheon Oakley Systems, LLC | RELEASE OF SECURITY INTEREST IN PATENTS | 055492 | /0146 | |
Jan 08 2021 | Raytheon Company | PORTAUTHORITY TECHNOLOGIES, LLC FKA PORTAUTHORITY TECHNOLOGIES, INC | RELEASE OF SECURITY INTEREST IN PATENTS | 055492 | /0146 | |
Jan 08 2021 | Raytheon Company | WEBSENSE, INC | RELEASE OF SECURITY INTEREST IN PATENTS | 055492 | /0146 | |
Jan 08 2021 | REDOWL ANALYTICS, INC | CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 055052 | /0302 | |
Jan 08 2021 | Forcepoint LLC | CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 055052 | /0302 | |
Apr 01 2021 | Forcepoint LLC | FORCEPOINT FEDERAL HOLDINGS LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 056216 | /0309 | |
Sep 29 2023 | FORCEPOINT FEDERAL HOLDINGS LLC | APOLLO ADMINISTRATIVE AGENCY LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 065086 | /0822 | |
Sep 29 2023 | CREDIT SUISSE, AG, CAYMAN ISLANDS BRANCH, AS COLLATERAL AGENT | FORCEPOINT FEDERAL HOLDINGS LLC F K A FORCEPOINT LLC | PARTIAL PATENT RELEASE AND REASSIGNMENT AT REEL FRAME 055052 0302 | 065103 | /0147 |
Date | Maintenance Fee Events |
Oct 01 2013 | ASPN: Payor Number Assigned. |
Apr 13 2017 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Apr 14 2021 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Oct 29 2016 | 4 years fee payment window open |
Apr 29 2017 | 6 months grace period start (w surcharge) |
Oct 29 2017 | patent expiry (for year 4) |
Oct 29 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Oct 29 2020 | 8 years fee payment window open |
Apr 29 2021 | 6 months grace period start (w surcharge) |
Oct 29 2021 | patent expiry (for year 8) |
Oct 29 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Oct 29 2024 | 12 years fee payment window open |
Apr 29 2025 | 6 months grace period start (w surcharge) |
Oct 29 2025 | patent expiry (for year 12) |
Oct 29 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |