SYSTEM AND METHOD FOR CONTINUOUS COLLECTION, ANALYSIS AND REPORTING OF ATTACK PATHS IN A DIRECTORY SERVICES ENVIRONMENT
A system and method for analyzing directory service environment attack paths for an enterprise may continuously collect data about the attack paths and provide alerts. The system and method may also analyze the nested object relationships within Directory Services alongside objects at risk for Credential Theft to calculate all possible attack paths within the environment.
Appendix A (20 pages) contains an example of user data collected by the attack path determining system and method, an example of computer data collected by the attack path determining system and method; an example of group data collected by the attack path determining system and method, an example of domain data collected by the attack path determining system and method, an example of group policy object data collected by the attack path determining system and method and an example of organizational unit data collected by the attack path determining system and method. Appendix A forms part of the specification and incorporated herein.
FIELDThe disclosure relates generally to a system and method for determining attack paths in an enterprise system and in particular to a system and method for collecting, analyzing the reporting attack paths in a directory services environment.
BACKGROUNDEnterprise security teams use Directory Services solutions to manage permissions and access to networked resources. These teams are responsible with ensuring the right assets (users, groups of users, and computers) have just enough access to other assets within the network to complete their job duties but no more. This is critical for two reasons: 1) excessive permissions open paths for malicious actors to operate and execute (that may be known as “Attack Paths”) in the pursuit of their objective once gaining initial access within the environment; and 2) excessive permissions increase insider threat risk from users with unnecessary access to sensitive data.
One challenge with Directory Services is the cascading permissions that can be granted to an asset either through nested permissions either directly or indirectly by associating it with another Directory Services asset. This introduces a “Russian Doll” effect of nested permissions that can excessively expose assets within the environment.
Another challenge with Directory Services is the manner in which user credentials or access tokens are stored after accessing other assets within the network. Harvesting, misusing, or hijacking these credentials and tokens (that may be known as “Credential Theft”) is trivial for malicious actors who use these to continue to execute lateral movement and complete their objectives.
No solution designed to analyze permissions in Directory Services uses both analysis of token risk with un-nested asset permissions in the calculation of all possible Attack Paths. This leads to a partial and incorrect picture of exposure risk for the environment. Additionally, no system today analyzes all possible Attack Paths in a continuous basis because current solutions focus on point-in-time scans only. The total number of Attack Paths is in a constant state of flux due to daily changes to Directory Services assets (e.g. users added to new groups leading to new nested permissions) and users logging in to other network resources (new Credential Theft risk). Continuous analysis facilitates alerting on an increase in the number of Attack Paths that expose critical assets to compromise.
Finally, no system today presents findings and recommendations from a Tiering Isolation viewpoint. Tiering Isolation is a security and administrative best practice for the management of Directory Services infrastructure. Systems in place today overload administrative and security personnel with generic alerting which do not focus on reducing the total Attack Paths connecting tiered enterprise assets. Proper segmentation of privilege through Tiering Isolation effective cuts the Attack Paths available for compromise and dramatically hardens the network against attackers.
Currently, there is an open source program publicly available from the assignee of the present application called “BloodHound Free and Open-Source” (“BloodHound FOSS”) (publicly accessible and available at github.com/BloodHoundAD/BloodHound). BloodHound FOSS is a tool used by ethical hacking professionals who conduct penetration testing or red team operations against corporate client networks. These engagements are designed to emulate attacker activities and complete one or more target objectives to test the security of the environment.
BloodHound FOSS is built to identify a path to a target objective to an authorized ethical hacker. This user will execute BloodHound FOSS to map the available Attack Paths from a computer under his or her control. Once the Attack Graph is populated, the user chooses an Attack Path to pursue and conducts follow-on activities in the pursuit of their target objective. While BloodHound FOSS can identify the available Attack Paths utilizing analysis of both nested relationships and Credential Theft, it does so only from the viewpoint of a single system, is executed as a point-in-time snapshot versus continuous collection and analysis. BloodHound FOSS also is unable to aggregate data collected from multiple sources in an automated manner. BloodHound FOSS only provides the options for users to execute to move to a target objective, it does not provide detailed descriptions of the underlying objects or provide recommendations for defensive mitigation or remediation strategies.
Thus, it is desirable to provide a system and method for continuous collection, analysis and reporting of attack paths in a directory services environment that is not currently provided by the above described existing systems and methods and it is to this end that the disclosure is directed.
The disclosure is particularly applicable to an enterprise system and method for continuously collecting, analyzing and reporting attack paths for a Microsoft® Active Directory (AD) directory services environment with traditional IT components and it is in this context that the disclosure will be described. It will be appreciated, however, that the system and method has greater utility, such as other Directory Services and or Identity and Access Management (IAM) infrastructures that might have slightly different architectures and/or different or additional IT components all of which are within the scope of this disclosure. For example, the system and method may be used to detect attack paths with any network using any operating system and any directory services system such as Azure Active Directory and Amazon Web Services (AWS) IAM.
An embodiment of the system and method for continuously collecting, analyzing and reporting attack paths present in Directory Services may be known as BloodHound Enterprise. The system and method are different than other known systems due to its comprehensive dataset, continuous analysis, and structural presentation in a logical tiered isolation view. Unlike other technologies, the system and method analyzes the nested object relationships within Directory Services alongside objects at risk for Credential Theft to calculate all possible attack paths within the environment. This analysis may be done in a continuous manner beginning with the centralized collection of relevant data sources through a mix of active device interrogation and streaming event collection. These data sources represent the necessary pre-requisite elements which the system ingests into a graph database which is then run through an analytics engine to identify all possible Attack Paths. As Attack Paths are discovered, they can either be served in real-time as a bespoke alert for security personnel or can be grouped by commonality to identify chokepoints within Directory Services tiers that an actor can use to elevate privilege and complete their objective.
These tier privilege chokepoints represent flaws according to security best practices in Privileged Account Management (PAM) models for Directory Services. The most well-known PAM model for Directory Services is Microsoft's “Active Directory Administrative Tier Model” (disclosed and accessible at the following publicly accessible website: docs.microsoft.com/en-us/windows-server/identity/securing-privileged-access/securing-privileged-access-reference-material.) In this model, assets are grouped into three tiers:
- Tier 0—the most critical assets and users with power over the entire enterprise
- Tier 1—assets and users with control over enterprise servers and applications with significant business value such as a database server containing social security numbers for a health care provider
- Tier 2—assets and users with control over user workstation and devices such as Help Desk and computer support administrators
In this tier structure, it is understood that users and assets within a specific tier should only conduct administrative actions within that specific tier. This is done to protect systems “using a set of buffer zones between full control of the Environment (Tier 0) and the high-risk workstation assets that attackers frequently compromise”. However, no system currently exists which allows administrators to understand the Attack Paths that may cross these boundaries either through their faulty implementation of Directory Services permissions or through the login activity of their users. The disclosed system provides Directory Services Administrators with this comprehensive, real-time tiered isolation view of their environment and aggregates the Attack Paths connecting these tiers that violate this PAM model and allow malicious actors to complete their target objective as discussed in more detail below.
Unlike the open source Bloodhound FOSS program that collects data from a single source, perform manual, point in time data collection and presents Attack Paths for users to use in pursuit of a target objective as described above, the disclosed system and method, such as that implemented in the Bloodhound Enterprise embodiment, is different for a number of reasons. First, the disclosed system and method aggregates data from multiple collection points across multiple networks and performs continuous data collection which are not possible using the Bloodhound FOSS program. Furthermore, the disclosed system and method identifies all Attack Paths for the purpose of defensive mitigation and elimination, presents Tiering Isolation Structure for isolating privilege in accordance with security and administrative best practice. groups Attack Paths by common elements, prioritizes Attack Path remediations by impact and severity and provide proactive alerting to highlight newly observed Attack Paths that are also not possible using the Bloodhound FOSS program.
One component of the enterprise IT infrastructure, whether on-premise, cloud-hosted, or hybrid environment, is the one or more Directory Services system(s) 106. These are a shared information infrastructure for locating, managing, administering and organizing everyday items and network resources, which can include volumes, folders, files, printers, users, groups, devices of any operating system, telephone numbers and other objects. A directory service (implement by the one or more directory service system(s)) is a critical component of a network operating system and each resource on the network is considered an object by the directory service server that is part of the directory service system 106. Information about a particular resource is stored as a collection of attributes, including which resource has permissions to perform particular actions, such as accessing, deleting or modifying the resource amongst others, or are associated with that resource or object. This information can be stored centrally by the Directory Services system 106 itself or within the Directory Services resources or objects directly.
One of the duties performed by Directory Services is to dictate which resources have access to other resources. For example, Directory services may specify that the “HelpDesk” user group has the ability to modify the passwords of users within the environment in order to facilitate regular operations within the organization. Similarly, the “Finance” group may be granted the right to access a certain group of files “Taxes” within a “Finance Servers” enclave to both support the access requirements to complete a task but also to block other, non-Finance users from accessing sensitive information. Thus, Directory Services grants or denies access rights to a resource for various actions.
Directory Services rights may be explicitly granted or delegated. For example, an administrator may define, within the Directory Services Server or instance, the user group for “Finance”. This group may include all the relevant employees within the Finance organization. Next, the Administrator may define the group of machines “Finance Servers” which the organization utilizes. The Administrator may define a right for the “Finance” group to have access to the “Finance Servers”. Therefore, any new user added to “Finance” would be automatically granted the rights to the resources he or she may need to complete their regular duties. This is an example of a delegated right that is inherited due to the other rights in the Directory Services system.
Similarly, the Directory Services rights can be explicitly granted through individual systems. For example “Jim”, a member of the “Legal” group, may temporarily or permanently require the need to access information hosted within a system which is grouped under “Finance Servers”. This individual does not belong to the user group for “Finance” and would not automatically be granted the inherited rights to complete their task. In this instance, the administrator may choose to modify the local access rights within the server named “FINSERV0001” located within “Finance Servers” and grant “Jim” access rights. This is an example of an explicitly granted right.
It is important to note that rights that were granted explicitly may or may not be represented by the Directory Services server but rather within the individual systems or objects under which this right was granted. In other words, the Directory Services server may not be aware that “Jim” has rights to “FINSERV0001” when, in fact, he does have access rights to that system.
The attack path determining system 10 shown in
The attack path determining system 10 may include a Data Collector 110, which may be run as a Virtual Machine (VM), Container, or as services on top of any base Operating systems (OS) and collects relevant data from one or more data sources 100 which reside within an environment that includes the system 10. For example, each of the one or more domain computers 102, the domain controller 101 and the centralized Security Information and Event Management (SIEM) system 103 shown in
The graph database 130 is a known type of database that has nodes and edges that are used to store data and the relationships between the data. In the system 10 in
An Analytics and Alerting Engine 140 extracts data/queries data/requests data from the graph database 130. The Analytics and Alerting Engine 140 may then run a set of analysis across the Graph Database 130 either in continuous or batch processes which can generate alerts and intelligence that may be surfaced to a Directory Services Administrator, Information Security Representative, or others.
An example of the set of rules are now described. The set of rules may be categorized such that each rule identifies a particular attack path and has a recommended solution to the identified particular attack path. For example, the set of rules may have a plurality of rules that identify: 1) attack path to Tier 0 assets in a network; 2) abuseable Kerberos configurations; 3) Least Privilege Enforcement and Privileged Account Management, etc. The plurality of rules for identifying attack path to Tier 0 assets each seek to remove those attack paths to Tier 0 assets in the enterprise network. Each rule for attack path to Tier 0 assets may have a different remediation of the problem. For example, one rule may restrict Tier 0 User Account Logons, another rule may remove Users and Groups from Local Groups on Tier 0 Computers, another rules may restrict Control of Group Policy Objects (GPOs) that Apply to Tier 0 Assets and another rule may restrict Control of Tier 0 Objects.
The plurality of rules for identifying abuseable Kerberos configurations each seek to resolve these configuration problems so that an attacker cannot use those configurations maliciously and gain improper access to assets of the network. Each rule for abuseable Kerberos configurations may have a different remediation of the problem. For example, one rule may harden or remediate Kerberoastable User Accounts, another rule may address Computers Trusted for Unconstrained Delegation and another rule may restrict Control of Computers Trusted for Unconstrained Delegation. A computer trusted for unconstrained delegation means that the asset has trust to delegate access to any service.
The plurality of rules for identifying least privilege enforcement and privileged account management seek to resolve these issues by limiting the access rights for each asset to a minimum required access privilege. Each rule for least privilege enforcement may have a different solution. For example, one rule may trim Execution Rights Held by Large Security Groups and another rules may audit Potential Vulnerable Account Passwords, such as password that do not have strong passwords.
As shown in
The local group collection process 804 may perform a computer collection (804a) that gathers computer objects from LDAP from the domain controller. The process 804 may, for each computer in the active directory gathered above, perform a TCP connect on port 445 to check if the host is alive (804b, 804c). If the host is not alive, the method moves to the next computer (804d) and restarts this process 804 at the top. If the host is alive, the method 804 may perform a NETAPI call (804e) that is a modified version of the NetLocalGroupGetMembers NET32API call and requires privileged access. The method is completed when all of the computers are analyzed. Examples of the various types of data collected by the method 800 shown in
The user session collection method 806 may perform a computer collection (806a) that gathers computer objects from LDAP from the domain controller for each user. The process 806 may, for each computer in the active directory gathered above, perform a TCP connect on port 445 to check if the host is alive (806b, 806c). If the host is not alive, the method moves to the next computer (806d) and restarts this process 806 at the top. If the host is alive, the method 806 performs a NETAPI call that is a NetSessionEnum NET32 API call (806e) to collect network sessions that are established to host and from where the network sessions are created when network resources, such as file shares, are accessed. The method 806 may perform another NETAPI call (806f) that is a NetWkstaUserEnum NET32 API call to collect more accurate user session data by asking for who is logged in to the system which requires privileged access. The method 806 may then perform a remote registry process (806g) that collects subkeys within a remote registry that match the SID format and corresponds to logged on user. The method is completed when all of the computers are analyzed.
Examples of Attack Path Determination and AlertingTo illustrate the operation of the attack path determining system and method is more detail, an example of the process using an example situation in the network will now be described.
In this example in
FIG.16 illustrates an in-depth view of the objects within the Attack Graph. Here, the Attack Path Meta-Node 612 for Tier 0 assets at the top of the graphic is expanded to reveal the Attack Path Meta-Elements 613 contained within. The Attack Path Meta-Element 613 for groups is expanded and an individual Group 622 is highlighted. This Group 622 is connected to another Attack Path Element 620 from the Tier 1 assets layer by an Attack Path Edge 640. This Attack Path Element 620 is itself another Group 622. This interface is allowing the user to start first with an overview of all aggregated elements before inspecting individual connections and moving to mitigation and remediation.
The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the disclosure to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the disclosure and its practical applications, to thereby enable others skilled in the art to best utilize the disclosure and various embodiments with various modifications as are suited to the particular use contemplated.
The system and method disclosed herein may be implemented via one or more components, systems, servers, appliances, other subcomponents, or distributed between such elements. When implemented as a system, such systems may include an/or involve, inter alia, components such as software modules, general-purpose CPU, RAM, etc. found in general-purpose computers. In implementations where the innovations reside on a server, such a server may include or involve components such as CPU, RAM, etc., such as those found in general-purpose computers.
Additionally, the system and method herein may be achieved via implementations with disparate or entirely different software, hardware and/or firmware components, beyond that set forth above. With regard to such other components (e.g., software, processing components, etc.) and/or computer-readable media associated with or embodying the present inventions, for example, aspects of the innovations herein may be implemented consistent with numerous general purpose or special purpose computing systems or configurations. Various exemplary computing systems, environments, and/or configurations that may be suitable for use with the innovations herein may include, but are not limited to: software or other components within or embodied on personal computers, servers or server computing devices such as routing/connectivity components, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, consumer electronic devices, network PCs, other existing computer platforms, distributed computing environments that include one or more of the above systems or devices, etc.
In some instances, aspects of the system and method may be achieved via or performed by logic and/or logic instructions including program modules, executed in association with such components or circuitry, for example. In general, program modules may include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular instructions herein. The inventions may also be practiced in the context of distributed software, computer, or circuit settings where circuitry is connected via communication buses, circuitry or links. In distributed settings, control/instructions may occur from both local and remote computer storage media including memory storage devices.
The software, circuitry and components herein may also include and/or utilize one or more type of computer readable media. Computer readable media can be any available media that is resident on, associable with, or can be accessed by such circuits and/or computing components. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and can accessed by computing component. Communication media may comprise computer readable instructions, data structures, program modules and/or other components. Further, communication media may include wired media such as a wired network or direct-wired connection, however no media of any such type herein includes transitory media. Combinations of the any of the above are also included within the scope of computer readable media.
In the present description, the terms component, module, device, etc. may refer to any type of logical or functional software elements, circuits, blocks and/or processes that may be implemented in a variety of ways. For example, the functions of various circuits and/or blocks can be combined with one another into any other number of modules. Each module may even be implemented as a software program stored on a tangible memory (e.g., random access memory, read only memory, CD-ROM memory, hard disk drive, etc.) to be read by a central processing unit to implement the functions of the innovations herein. Or, the modules can comprise programming instructions transmitted to a general purpose computer or to processing/graphics hardware via a transmission carrier wave. Also, the modules can be implemented as hardware logic circuitry implementing the functions encompassed by the innovations herein. Finally, the modules can be implemented using special purpose instructions (SIMD instructions), field programmable logic arrays or any mix thereof which provides the desired level performance and cost.
As disclosed herein, features consistent with the disclosure may be implemented via computer-hardware, software and/or firmware. For example, the systems and methods disclosed herein may be embodied in various forms including, for example, a data processor, such as a computer that also includes a database, digital electronic circuitry, firmware, software, or in combinations of them. Further, while some of the disclosed implementations describe specific hardware components, systems and methods consistent with the innovations herein may be implemented with any combination of hardware, software and/or firmware. Moreover, the above-noted features and other aspects and principles of the innovations herein may be implemented in various environments. Such environments and related applications may be specially constructed for performing the various routines, processes and/or operations according to the invention or they may include a general-purpose computer or computing platform selectively activated or reconfigured by code to provide the necessary functionality. The processes disclosed herein are not inherently related to any particular computer, network, architecture, environment, or other apparatus, and may be implemented by a suitable combination of hardware, software, and/or firmware. For example, various general-purpose machines may be used with programs written in accordance with teachings of the invention, or it may be more convenient to construct a specialized apparatus or system to perform the required methods and techniques.
Aspects of the method and system described herein, such as the logic, may also be implemented as functionality programmed into any of a variety of circuitry, including programmable logic devices (“PLDs”), such as field programmable gate arrays (“FPGAs”), programmable array logic (“PAL”) devices, electrically programmable logic and memory devices and standard cell-based devices, as well as application specific integrated circuits. Some other possibilities for implementing aspects include: memory devices, microcontrollers with memory (such as EEPROM), embedded microprocessors, firmware, software, etc. Furthermore, aspects may be embodied in microprocessors having software-based circuit emulation, discrete logic (sequential and combinatorial), custom devices, fuzzy (neural) logic, quantum devices, and hybrids of any of the above device types. The underlying device technologies may be provided in a variety of component types, e.g., metal-oxide semiconductor field-effect transistor (“MOSFET”) technologies like complementary metal-oxide semiconductor (“CMOS”), bipolar technologies like emitter-coupled logic (“ECL”), polymer technologies (e.g., silicon-conjugated polymer and metal-conjugated polymer-metal structures), mixed analog and digital, and so on.
It should also be noted that the various logic and/or functions disclosed herein may be enabled using any number of combinations of hardware, firmware, and/or as data and/or instructions embodied in various machine-readable or computer-readable media, in terms of their behavioral, register transfer, logic component, and/or other characteristics. Computer-readable media in which such formatted data and/or instructions may be embodied include, but are not limited to, non-volatile storage media in various forms (e.g., optical, magnetic or semiconductor storage media) though again does not include transitory media. Unless the context clearly requires otherwise, throughout the description, the words “comprise,” “comprising,” and the like are to be construed in an inclusive sense as opposed to an exclusive or exhaustive sense; that is to say, in a sense of “including, but not limited to.” Words using the singular or plural number also include the plural or singular number respectively. Additionally, the words “herein,” “hereunder,” “above,” “below,” and words of similar import refer to this application as a whole and not to any particular portions of this application. When the word “or” is used in reference to a list of two or more items, that word covers all of the following interpretations of the word: any of the items in the list, all of the items in the list and any combination of the items in the list.
Although certain presently preferred implementations of the invention have been specifically described herein, it will be apparent to those skilled in the art to which the invention pertains that variations and modifications of the various implementations shown and described herein may be made without departing from the spirit and scope of the invention. Accordingly, it is intended that the invention be limited only to the extent required by the applicable rules of law.
While the foregoing has been with reference to a particular embodiment of the disclosure, it will be appreciated by those skilled in the art that changes in this embodiment may be made without departing from the principles and spirit of the disclosure, the scope of which is defined by the appended claims.
Claims
1. An apparatus for analyzing attack paths in a directory services system of an enterprise infrastructure in which a permission to each asset in the enterprise infrastructure is managed by a directory services systems that is coupled to each of the one or more assets of the enterprise infrastructure, the apparatus comprising:
- a computer, located in a cloud and being connected to the one or more assets in a data center of the infrastructure of the enterprise, with a processor and a plurality of instructions executed by the processor that continuously collects data about one or more assets;
- a graph database coupled to the computer that stores the continuously collected data for the one or more assets; and
- the computer processor is further configured to retrieve data from the graph database to identify a plurality of attack paths for the one or more assets and the directory services system in the enterprise infrastructure.
2. The apparatus of claim 1, wherein the computer is further configured to generate an alert for each identified attack path.
3. The apparatus of claim 2, wherein the computer is further configured to convert the continuously collected data into a format for storage in the graph database.
4. The apparatus of claim 1, wherein the directory services is a Microsoft Active Directory system.
5. The apparatus of claim 1, wherein the one or more assets further comprises a domain controller, a domain computer and a security information and event system.
6. The apparatus of claim 1, wherein the computer and the graph database are in the enterprise infrastructure data center.
7. (canceled)
8. The apparatus of claim 1 further comprising a second computer in a cloud separate from the enterprise infrastructure data center configured to identity the attack paths and wherein the graph database is in the cloud.
9. The apparatus of claim 8, wherein the computer further comprises a set of rules wherein each rule has a condition that is tested against the continuously collected data of the network to identify an attack path.
10. The apparatus of claim 9, wherein the computer is further configured to execute continuously each rule in the set of rules.
11-12. (canceled)
13. The apparatus of claim 29, wherein the plurality of rules that identify abuseable Kerberos configurations further comprises a rule that hardens Kerberoastable User Accounts, a rule that addresses computers trusted for unconstrained delegation and a rule that restricts control of computers trusted for unconstrained delegation.
14. The apparatus of claim 29, wherein the plurality of rules that identify least privilege enforcement further comprises a rule that reduces execution rights held by large security groups and a rule that audits potential vulnerable account passwords.
15. A method for analyzing attack paths in a directory services system, the method comprising:
- continuously collecting data about one or more assets that are controlled by a directory services system, each asset being a device in an enterprise infrastructure that has its permissions determined by the directory services system;
- storing the collected data about the one or more assets in a graph database;
- performing an analysis of the collected data stored in the graph database to identify a plurality of attack paths for the one or more assets and the directory services system in the enterprise infrastructure; and
- generating an alert for each identified attack path.
16. The method of claim 15, wherein the directory services is a Microsoft Active Directory system.
17. The method of claim 15, wherein continuously collecting the data further comprises continuously collecting data from a domain controller, a domain computer and a security information and event system.
18. The method of claim 15 further comprising converting the data from the one or assets into a common format.
19. The method of claim 15, wherein performing the analysis further comprises testing a set of rules against the continuously collected data to identify one or more attack path.
20. The method of claim 19, wherein each rule in the set of rules has a condition that is tested against the continuously collected data of the network to identify the attack path.
21. The method of claim 20, wherein testing the set of rules further comprises continuously executing each rule in the set of rules against the continuously collected data.
22. An apparatus for analyzing attack paths in a directory services system, the apparatus comprising:
- an enterprise infrastructure having a plurality of locations wherein each location has one or more assets of the enterprise infrastructure, wherein a permission to each asset is managed by a directory services system;
- a computer based data collector unit housed in each location of the enterprise infrastructure and being connected to the one or more assets in the location, the data collector continuously collecting data about one or more assets in each location;
- a graph database, at different location from the plurality of locations of the enterprise infrastructure and being coupled to the each of the data collector units in each location, that stores the continuously collected data for the one or more assets; and
- a computer based analytics unit, coupled to the graph database and housed in the same location as the graph database, that retrieves data from the graph database to identify a plurality of attack paths for the one or more assets and the directory services system in the enterprise infrastructure.
23. The apparatus of claim 22 further comprising a computer based alerting unit coupled to the analytics unit that generates an alert for each identified attack path.
24. The apparatus of claim 23 further comprising a computer based data ingestor unit coupled between the data collector unit and the graph database that converts the continuously collected data into a format for storage in the graph database.
25. The apparatus of claim 22 wherein the directory services is a Microsoft Active Directory system.
26. The apparatus of claim 22, wherein the one or more assets further comprises a domain controller, a domain computer and a security information and event system.
27. The apparatus of claim 22, wherein the computer based analytics unit further comprises a set of rules wherein each rule has a condition that is tested against the continuously collected data of the network to identify an attack path.
28. The apparatus of claim 27, wherein the computer based analytics unit continuously executes each rule in the set of rules.
29. The apparatus of claim 9, wherein the set of rules further comprises a plurality of rules that identify Kerberos configurations that are abuseable and a plurality of rules that identify least privilege enforcement.
Type: Application
Filed: Apr 23, 2020
Publication Date: Oct 28, 2021
Inventors: Andrew ROBBINS (Alexandria, VA), Rohan VAZARKAR (Alexandria, VA), Ryan William SCHROEDER (Alexandria, VA)
Application Number: 16/857,039