
Windows Security Principals, Objects, Access Control, and NTFS Permissions
Windows Security Principals, Objects, Access Control, and NTFS Permissions: A Technical Deep Dive
Part 1: Conceptual Overview
1.1 Security Principals (Users, Groups, Computers)
Security Principals are entities in Windows that authentication systems recognize and assign permissions and rights to. Each principal has a unique Security Identifier (SID). The main types are:
- 
                    User Accounts: Represent people or service identities. - Local User Accounts: Stored and managed in the local Security Account Manager (SAM) database on a specific machine. Their scope is limited to that machine.
- Domain User Accounts: Stored and managed in Active Directory Domain Services (AD DS). Authenticated by a Domain Controller (DC), they can access resources across the domain or forest, based on permissions.
 
- Local User Accounts: Stored and managed in the local Security Account Manager (
- 
                    Group Accounts: Collections of other principals (users, computers, other groups) that simplify managing permissions and rights. - Security Groups: Used in Access Control Lists (ACLs) to grant or deny permissions.
- Distribution Groups: Primarily for email lists (like in Microsoft Exchange); cannot assign permissions in ACLs.
- 
                            Group Scopes (in AD DS): Control membership and usability: - Domain Local: Can contain members (users, global groups, universal groups) from any domain in the forest, plus other domain local groups from the same domain. Mainly used to grant permissions to resources within its own domain.
- Global: Can contain members (users, computers, other global groups) only from its own domain. Can be granted permissions in any domain in the forest or trusting domains. Often aggregates users with similar roles within a domain.
- Universal: Can contain members (users, global groups, universal groups) from any domain in the forest. Can be granted permissions anywhere in the forest. Membership is replicated to the Global Catalog (GC), increasing replication traffic. Best for stable, small groups representing forest-wide roles.
 
- Local Groups (Machine Local): Defined in the local SAMdatabase. Can contain local users, domain users, domain global groups, and domain universal groups. Used to grant permissions only to resources on the local machine.
 
Choosing the right group type and scope is vital for building scalable and manageable access control in Active Directory. It involves balancing administration, control granularity, and replication load. Wrong scope choices can limit permission assignments or cause overly large access tokens due to extensive Universal group membership replicated via the GC.
- Computer Accounts: Represent devices like workstations and servers in a domain (managed in AD DS) or standalone machines (localSAM). Used for machine authentication (e.g., accessing network resources, applying machine-targeted Group Policies) and secure communication between machines.
1.2 Security Identifiers (SIDs)
A Security Identifier (SID) is a unique, fixed, variable-length value assigned by the Local Security Authority (LSA) or a Domain Controller's LSA to identify a security principal or logon session. It includes a revision level, a 48-bit identifier authority value, and several 32-bit subauthority values, ending with a Relative Identifier (RID) that's unique within the issuing authority's domain (either the machine SAM or the AD domain).
The uniqueness and permanence of SIDs ensure Windows access control integrity. Once assigned, a SID is never reused, even if the principal is deleted and recreated with the same name. This prevents accidental permission inheritance. The $SIDHistory$ attribute in AD DS lets migrated objects keep old SIDs, ensuring continued resource access during transitions, but it complicates access token evaluation because the token contains multiple user/group SIDs.
Well-Known SIDs are predefined constants representing generic users or groups across all Windows systems. Examples include:
- $S-1-1-0$(Everyone)
- $S-1-5-18$(Local System)
- $S-1-5-32-544$(Administrators - local built-in group)
1.3 Objects
In Windows security, an object is any system entity whose access is controlled via a Security Descriptor. Objects represent system resources, such as:
- File system objects (Files, directories)
- Registry keys
- Printers
- Services
- Processes and Threads
- Kernel synchronization objects (Events, mutexes, semaphores, timers)
- Section objects (file mappings, shared memory)
- Network shares
- Active Directory objects (Users, groups, OUs, GPOs, sites, subnets)
- Windows Management Instrumentation (WMI) namespaces and objects
- Device objects
A securable object must have a Security Descriptor. This allows the system's Security Reference Monitor (SRM) to perform authorization checks when principals try to access it. The kernel's Object Manager manages kernel objects and calls the SRM for access validation.
1.4 Security Descriptors (SD)
A Security Descriptor (SD) is a data structure ($SECURITY_DESCRIPTOR$) linked to each securable object, holding its security settings. The SD defines who can do what to the object and which actions should be audited. SDs are stored with the object's metadata (e.g., in the NTFS Master File Table or $Secure stream for files) or managed by the component responsible for the object type (e.g., Registry, AD DS).
Key components of an SD:
- Owner SID: The SIDof the principal owning the object. The owner usually has implicit rights to read and change the object's Discretionary Access Control List (DACL), giving them control over permissions. Ownership can typically be taken by administrators or those with theSeTakeOwnershipPrivilege.
- Primary Group SID: Mainly for POSIX compatibility; generally not used in standard Win32 access control.
- Discretionary Access Control List (DACL): Contains Access Control Entries (ACEs) specifying which principals (users/groups) are allowed or denied specific access rights. It's "discretionary" because the object's owner controls it. A NULL DACLmeans access checks are bypassed (often effectively granting access). An emptyDACLdenies all access.
- System Access Control List (SACL): Contains ACEs specifying which access attempts (by whom, for what rights, success/failure) should trigger audit records in the Security Event Log. Accessing or changing the SACLrequires the$ACCESS_SYSTEM_SECURITY$right, usually granted via theSeSecurityPrivilege.
The SECURITY_DESCRIPTOR also has Control Flags that define attributes like ACE inheritance rules for child objects and whether the SD is in self-relative (single memory block) or absolute (pointers) format. Separating DACL and SACL allows distinct management of access control (by owners/delegates) and audit policy (by security administrators).
1.5 Access Control Lists (ACLs) & Access Control Entries (ACEs)
An Access Control List (ACL) is an ordered list of Access Control Entries (ACEs). Both DACLs and SACLs are ACLs.
An Access Control Entry (ACE) is the basic unit within an ACL. Each ACE identifies a trustee (a SID for a user, group, computer, or session) and specifies an access mask defining the permissions being allowed, denied, or audited for that trustee.
Key ACE characteristics:
- 
                    ACE Types: Common types are: - ACCESS_ALLOWED_ACE_TYPE: Grants specified access rights.
- ACCESS_DENIED_ACE_TYPE: Explicitly denies specified access rights.
- SYSTEM_AUDIT_ACE_TYPE: Specifies access attempts to be audited.
- Object-Specific ACEs (e.g., ACCESS_ALLOWED_OBJECT_ACE_TYPE): Used mainly inAD DSfor permissions on specific object classes or attributes.
 
- Access Mask: A 32-bit value where bits represent access rights. Includes generic rights (e.g., GENERIC_READ), standard rights (e.g.,DELETE,READ_CONTROL,WRITE_DAC,WRITE_OWNER), and object-specific rights (e.g., file rights likeFILE_READ_DATA,FILE_WRITE_DATA).
- 
                    Inheritance Flags: Control how an ACEon a container (like a directory) propagates to child objects:- OBJECT_INHERIT_ACE (OI): Inherited by child non-container objects.
- CONTAINER_INHERIT_ACE (CI): Inherited by child container objects.
- INHERIT_ONLY_ACE (IO): Applies only to inheriting children, not the object itself.
- NO_PROPAGATE_INHERIT_ACE (NP): Inherited only by immediate children; prevents further propagation.
 
For DACLs, ACE order is crucial. Windows enforces canonical order for predictable evaluation:
- Explicit Deny ACEs
- Explicit Allow ACEs
- Inherited Deny ACEs
- Inherited Allow ACEs
The SeAccessCheck function processes ACEs sequentially, relying on this order. Deny ACEs take precedence over Allow ACEs, and explicit ACEs take precedence over inherited ones. Non-canonical DACLs can cause unpredictable access decisions. Permission tools usually enforce canonical order automatically.
1.6 NTFS Permissions
NTFS permissions are the specific way Windows access control (SDs, ACLs, ACEs) applies to files and directories on NTFS volumes. They aren't a separate system, but specific access rights defined in the access masks of ACEs within the Security Descriptors of file system objects.
NTFS uses basic permissions (Read, Write, Read & Execute, Modify, Full Control) in UIs like Windows Explorer. These map to combinations of specific (Advanced) NTFS access rights:
- FILE_LIST_DIRECTORY/- FILE_READ_DATA
- FILE_ADD_FILE/- FILE_WRITE_DATA
- FILE_ADD_SUBDIRECTORY/- FILE_APPEND_DATA
- FILE_TRAVERSE/- FILE_EXECUTE
- DELETE
- READ_CONTROL
- WRITE_DAC
- WRITE_OWNER
- FILE_READ_ATTRIBUTES,- FILE_WRITE_ATTRIBUTES
- FILE_READ_EA,- FILE_WRITE_EA
Permission inheritance, controlled by flags (OI, CI, IO, NP) in parent ACEs and object SD control flags, allows permissions on containers to automatically apply to new child objects. This simplifies management but can create complex effective permissions. Evaluation follows canonical order: explicit overrides inherited, Deny overrides Allow at the same level.
1.7 Access Tokens
An Access Token (TOKEN) is a kernel object created by the Local Security Authority (LSA - lsass.exe) after successful user authentication. It holds the user's security context for the logon session and is attached to processes created in that session. Threads usually inherit the process token but can use their own impersonation tokens.
The Access Token contains info used by the SRM for access checks:
- User's SID: The primary identifier.
- Group SIDs: All groups the user belongs to (including transitive memberships and $SIDHistory$).
- Privileges: Assigned rights (e.g., SeShutdownPrivilege,SeBackupPrivilege).
- Default DACL: For objects created without a specific SD.
- Primary Group SID: For POSIX compatibility.
- Token Source: Who created the token.
- Authentication ID (AUTHID/Logon ID): Links token to a logon session.
- Token Type: PrimaryorImpersonation.
- Impersonation Level: If applicable (Anonymous, Identification, Impersonation, Delegation).
- Other attributes: Integrity level, session ID, flags.
The Access Token acts as the principal's credentials for authorization checks. The SRM compares the SIDs and privileges in the token against the object's SD. This avoids repeated authentication or lookups. Because the token contains the full context at logon, changes (like group membership) usually require logging off and back on to get a new token.
Two main token types:
- Primary Token: For a process's default security context. Generated at logon.
- Impersonation Token: For a thread, allowing temporary use of another security context (e.g., a client accessing a server). Limited by impersonation level.
1.8 Core Components Interaction
How these components work together for Windows authentication and authorization:
- Authentication: User logs on (e.g., via winlogon.exe). Credentials go toLSA(lsass.exe).LSAuses an Authentication Package (e.g.,Kerberos,MSV1_0) to verify against the authority (SAMor Active Directory).
- Token Generation: If authentication succeeds, LSAgathers userSID, groupSIDs, and privileges.LSAbuilds an Access Token (TOKEN) with this context.
- Process Creation: The user's first process (e.g., explorer.exe) gets the new Primary Access Token. Subsequent processes inherit it.
- Object Access Attempt: A thread tries an operation on a securable object (e.g., CreateFileW), specifying desired access rights.
- Access Check: The kernel's Object Managercalls the Security Reference Monitor (SRM).SRMgets the thread's token and the object'sSecurity Descriptor.
- Authorization Decision: SRMruns the access check (SeAccessCheck), comparing tokenSIDs to DACL ACEs, checking privileges, considering requested rights, and following canonical order (Deny before Allow, explicit before inherited).
- Result: SRMgrants or denies access. Granted access allows the operation (e.g., returns a file handle). Denied access returns an error (e.g.,$STATUS_ACCESS_DENIED$), usually seen as "Access Denied".
This shows separation: LSA handles authentication, SRM/Object Manager handle authorization using the token (identity) and SD (policy). The token links authentication to authorization.
Part 2: Technical Deep Dive
2.1 Core Security Architecture & Components
2.1.1 Involved Components
Local Security Authority (LSA - lsass.exe): The core user-mode security process (%SystemRoot%\System32\lsass.exe). Manages authentication via Authentication Packages (*.dll like kerberos.dll, msv1_0.dll), creates Access Tokens, manages LSA Policy (including LSA Secrets), interacts with SAM and NetLogon. Hosts Security Support Providers (SSPs) via SSPI. On DCs, also hosts KDC and AD DS components. A prime target for credential theft.
Security Account Manager (SAM): Service managing the local principal database (SAM file). Implemented by SamSrv.dll within lsass.exe. Provides APIs for LSA to validate local credentials.
Active Directory Domain Services (AD DS): On Domain Controllers (DCs). Core logic (Directory System Agent - DSA, ntdsa.dll) runs in lsass.exe, manages the NTDS.dit database. Stores domain principals, attributes (SIDs, memberships, $SIDHistory$), AD object SDs ($nTSecurityDescriptor$), and Group Policy.
Kerberos Key Distribution Center (KDC): Service on all DCs (kdcsvc.dll in lsass.exe). Includes Authentication Service (AS - issues TGTs) and Ticket-Granting Service (TGS - issues Service Tickets). Authenticates principals using secrets from AD DS.
NetLogon Service: (netlogon.dll, usually in lsass.exe). Manages secure RPC channel to DCs, DC discovery, pass-through authentication, and secure password changes.
Security Reference Monitor (SRM): Kernel executive component (ntoskrnl.exe). Enforces access control and auditing. Includes functions like SeAccessCheck, privilege checks (SePrivilegeCheck), and manages kernel TOKEN objects. Compares token SIDs/privileges against object SDs.
Object Manager: Kernel executive component (ntoskrnl.exe). Manages kernel object lifecycle and namespace. Calls SRM for access validation before granting object handles (via ObOpenObject* functions). Associates SDs with objects.
2.1.2 Storage Mechanisms
- SAM Database (%SystemRoot%\System32\config\SAM): Registry hive storing local users, groups, hashed passwords, and potentially cached domain credentials. Access strictly viaLSA/SAMAPIs. Protected by system ACLs and related to the System Key (SYSKEY).
- Active Directory Database (NTDS.dit): Default:%SystemRoot%\NTDSon DCs. Extensible Storage Engine (ESE) database holding all domain objects and attributes (SIDs, groups, hashed passwords, Kerberos keys,nTSecurityDescriptor). Accessed viaLDAPbyDSA(inlsass.exe).
- 
                    Registry: Contains security configurations: - HKLM\SECURITY: Pointers to- SAM, stores- LSA Secrets(e.g., service account passwords). Highly protected.
- HKLM\SYSTEM\CurrentControlSet\Control\Lsa: Settings for LSA, auth packages, security providers.
- HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList: Maps user- SIDs to profile paths.
- HKLM\SYSTEM\CurrentControlSet\Services: Service configuration, including security context (service account).
 
- 
                    Group Policy Objects (GPOs): Consists of two parts: - Group Policy Container (GPC): AD DS object with GPO metadata.
- Group Policy Template (GPT): Files in SYSVOLshare (\\). Contains actual policy settings (\SYSVOL\ \Policies\{GPO_GUID} .polfiles,.inftemplates, scripts). GPOs define settings like password policies, user rights, audit policies, ACLs, applied by clients.
 
2.1.3 Primary Protocols
Kerberos (RFC 4120): Default authentication in AD DS. Uses UDP/TCP port 88 for client-KDC communication. Uses tickets (TGT, Service Tickets) for strong mutual authentication. Authorization data (SIDs) usually in the Privilege Attribute Certificate (PAC) inside Service Tickets.
NTLMv2: Challenge/response protocol for local logons, workgroups, or Kerberos fallback. Handled by msv1_0.dll. Less secure than Kerberos, vulnerable to relay attacks.
LDAP (Lightweight Directory Access Protocol): For querying/modifying Active Directory. Clients use LDAP (TCP/UDP 389) or LDAPS (TCP 636) to talk to DCs. Global Catalog uses ports 3268 (LDAP) and 3269 (LDAPS).
Secure RPC (Remote Procedure Call): For inter-process communication, often administrative/infrastructure tasks. Used by LSA RPC, SAMRPC, NetLogon RPC, DRS RPC (AD replication). Runs over named pipes (via SMB) or TCP, using Kerberos or NTLM (via SPNEGO) for security.
SMB/CIFS (Server Message Block / Common Internet File System): For remote file shares/named pipes (TCP 445). Requires authentication (Kerberos or NTLM via SPNEGO). Server-side enforces access control via SRM/file system using client's context against object's SD.
2.2 Logon Process & Access Token Creation
2.2.1 Logon Sequence (Focus: Kerberos Interactive Domain Logon)
- Secure Attention Sequence (SAS): User presses Ctrl+Alt+Del;winlogon.exeshows secure logon desktop.
- Credential Acquisition: User enters credentials via a Credential Provider.
- LSA Invocation: winlogon.execallsLsaLogonUser, passing credentials tolsass.exe.
- Authentication Package Selection: LSAselectskerberos.dllfor domain logon.
- AS Exchange (TGT Request): Kerberos package sends AS-REQ(username, realm, timestamp encrypted with user key derived from password) toKDC(port 88).
- KDC Validation & AS-REP: KDC AS verifies request using user's key from AD DS. If valid, generates TGT session key &TGT(encrypted withkrbtgtkey). SendsAS-REP(session key encrypted with user key, encryptedTGT) back.
- Client TGT Processing: Client decrypts session key part using derived user key, stores TGTand TGT session key in LSA cache.
- TGS Exchange (Service Ticket Request): Client sends TGS-REQfor local machineHOST SPN, includesTGTand authenticator (encrypted with TGT session key), toKDCTGS.
- KDC Validation & TGS-REP: KDC TGS validates TGTand authenticator. Retrieves user auth data (SIDs) fromAD DS, embeds inPAC(signed by KDC). CreatesService Ticket(encrypted with machine key, includesPAC). Generates service session key. SendsTGS-REP(encrypted service ticket, service session key encrypted with TGT session key) back.
- Client Service Ticket Processing: Client decrypts service session key, stores Service Ticket(withPAC) and service session key in cache.
- LSA Authorization Data Extraction: Kerberos package provides user identity and SIDs (from PAC) toLSA.LSAmay validatePAC.
- Local Policy Integration: LSAchecks local policy for additional group memberships andUser Rights(Privileges).
- Access Token Construction: LSAbuilds theTOKENkernel object with User SID, all Group SIDs, Privileges, etc.
- Logon Session Creation: LSAcreates Logon Session (with uniqueLUID) and links thePrimary Access Token.
- Shell Launch: LSAreturns token handle towinlogon.exe, which launches user shell (explorer.exeviauserinit.exe) with the token.
Network Logon (e.g., SMB) uses a similar TGS exchange for the target service's SPN (e.g., CIFS/ServerName). NTLMv2 uses a 3-message challenge-response sequence.
2.2.2 Key Processes, Services, Drivers
Processes: winlogon.exe, lsass.exe, services.exe, svchost.exe.
Services: LSA, KDC, NetLogon, SAM.
Drivers: ksecdd.sys, cng.sys, Auth Package DLLs (kerberos.dll, msv1_0.dll), netlogon.sys, network stack.
2.2.3 Access Token Structure (In Memory - TOKEN Object)
The kernel TOKEN object includes:
- AuthenticationId: Logon session- LUID.
- TokenId: Unique token instance- LUID.
- TokenType: Primary or Impersonation.
- ImpersonationLevel: Level allowed (Anonymous, Identification, Impersonation, Delegation).
- User: User- SID_AND_ATTRIBUTES.
- Groups: Array of enabled Group- SID_AND_ATTRIBUTES(domain, local, logon,- $SIDHistory$). Attributes include deny-only status.
- Privileges: Array of assigned- LUID_AND_ATTRIBUTES. Attributes indicate enabled status.
- DefaultOwnerIndex/- DefaultDacl: Defaults for new objects.
- PrimaryGroup: For POSIX.
- TokenSource: Creator identifier.
- SessionId: Terminal Services/RDP session ID.
- Security Attributes: Integrity Level SID, etc.
Resolved group memberships in the token optimize access checks but can cause token bloat.
2.3 Access Check Algorithm (Security Reference Monitor - SRM)
2.3.1 SeAccessCheck Process Detail (Kernel Function)
The SeAccessCheck kernel function performs authorization. Key steps:
Inputs: Subject's TOKEN, desired ACCESS_MASK, object's SECURITY_DESCRIPTOR, optional OBJECT_TYPE_LIST, GENERIC_MAPPING.
- Map Generic Rights: Translate generic rights (GENERIC_READ, etc.) to specific rights usingGENERIC_MAPPING. HandleMAXIMUM_ALLOWED.
- Check System Security Access: If ACCESS_SYSTEM_SECURITYrequested, check for enabledSeSecurityPrivilegein token.
- Check Write Owner Access: If WRITE_OWNERrequested, check for enabledSeTakeOwnershipPrivilege. Check if token User SID matches SD Owner SID (impliesREAD_CONTROL,WRITE_DAC).
- Check Write DAC Access: If WRITE_DACrequested, check if token User SID matches SD Owner SID (implicitly granted). Otherwise, requires explicit ACE.
- DACL Processing (Canonical Order): Iterate through ACEs, maintaining GrantedAccessMaskandRemainingDesiredMask.- Explicit Deny: If ACE SID matches enabled token SID, remove denied rights from RemainingDesiredMask. If mask becomes zero, deny access.
- Explicit Allow: If ACE SID matches enabled token SID, add granted rights to GrantedAccessMask, remove fromRemainingDesiredMask. If mask becomes zero, may grant access early.
- Inherited Deny/Allow: If needed, process inherited ACEs similarly.
 
- Explicit Deny: If ACE SID matches enabled token SID, remove denied rights from 
- Privilege Check Overrides: Check for privileges like SeBackupPrivilege(read),SeRestorePrivilege(write),SeTakeOwnershipPrivilege(take ownership),SeSecurityPrivilege(SACL access). Add corresponding rights toGrantedAccessMaskif privilege enabled, potentially overriding DACL denial.
- Final Comparison & Result: Compare final GrantedAccessMaskto originalDesiredAccessMask. If all requested bits granted, return TRUE. Otherwise, return FALSE with appropriate status code (e.g.,STATUS_ACCESS_DENIED,STATUS_PRIVILEGE_NOT_HELD).
Canonical DACL order is essential for deterministic results (Deny before Allow, explicit before inherited). Privileges are controlled exceptions.
2.3.2 Key Kernel Components
ntoskrnl.exe: Hosts SRM (Se*) and Object Manager (Ob*).
Object-Specific Resource Monitors: Subsystems like File System Drivers (ntfs.sys), Configuration Manager (registry), win32k.sys (UI), ntdsa.dll (AD) provide SDs and interact with SRM.
2.4 Access Check Failure Scenarios & Error Codes Table
Understanding access failures involves mapping scenarios to error codes and potential event logs (if auditing is enabled).
| Check Step | Scenario Description | Win32 Error Code | NTSTATUS Code | Potential Event Log ID (Security Log - Audit Failure) | 
|---|---|---|---|---|
| Privilege Check | Lacks required privilege (e.g., for SACL read). | ERROR_PRIVILEGE_NOT_HELD (1314) | STATUS_PRIVILEGE_NOT_HELD (0xC0000061) | 4656(Details mention required privilege). | 
| DACL Processing (Explicit Deny) | Token SID matches an Explicit Deny ACE for requested rights. | ERROR_ACCESS_DENIED (5) | STATUS_ACCESS_DENIED (0xC0000022) | 4656(Details mention Principal SID matching Deny ACE). | 
| DACL Processing (Insufficient Allow) | No Allow ACE grants requested rights for any token SID. | ERROR_ACCESS_DENIED (5) | STATUS_ACCESS_DENIED (0xC0000022) | 4656(Details mention insufficient rights). | 
| Owner Check | Not Owner and lacks necessary ACE ( WRITE_DAC,WRITE_OWNER). | ERROR_ACCESS_DENIED (5) | STATUS_ACCESS_DENIED (0xC0000022) | 4656(Details mention requested access). | 
| Object Type Specific Check | Denied by lower-level component (e.g., filter driver). | ERROR_ACCESS_DENIED (5)or custom | STATUS_ACCESS_DENIED (0xC0000022)or custom | 4656or custom event log entry. | 
| Impersonation Level Check | Operation requires higher impersonation level than token allows. | ERROR_ACCESS_DENIED (5) | STATUS_ACCESS_DENIED (0xC0000022) | 4656or related impersonation events. | 
| Invalid Security Descriptor | Object's SD is malformed or unreadable. | ERROR_INVALID_SECURITY_DESCR (1338) | STATUS_INVALID_SECURITY_DESCR (0xC0000079) | 4656or system errors. | 
ERROR_ACCESS_DENIED (5) requires deeper analysis, often using effective permissions tools or detailed auditing (Event ID 4656). ERROR_PRIVILEGE_NOT_HELD (1314) indicates missing User Rights.
2.5 NTFS Permissions Deep Dive
2.5.1 Generic vs. Specific Permission Mapping
NTFS permissions use specific file system rights. Basic Permissions in UIs map to combinations of Specific (Advanced) permissions.
| Basic Permission | Applies To | Specific NTFS Permissions Typically Included | 
|---|---|---|
| Read | Files & Folders | FILE_READ_DATA/FILE_LIST_DIRECTORY,FILE_READ_ATTRIBUTES,FILE_READ_EA,READ_CONTROL | 
| Write | Files & Folders | FILE_WRITE_DATA/FILE_ADD_FILE,FILE_APPEND_DATA/FILE_ADD_SUBDIRECTORY,FILE_WRITE_ATTRIBUTES,FILE_WRITE_EA,READ_CONTROL | 
| Read & Execute | Files & Folders | Read permissions + FILE_EXECUTE/FILE_TRAVERSE | 
| List Folder Contents | Folders Only | (Special GUI) FILE_LIST_DIRECTORY,FILE_READ_ATTRIBUTES,FILE_READ_EA,FILE_TRAVERSE,READ_CONTROL. Different inheritance. | 
| Modify | Files & Folders | Read & Execute + Write + DELETE | 
| Full Control | Files & Folders | Modify permissions + WRITE_DAC,WRITE_OWNER | 
Understanding this mapping helps apply least privilege. Fine-grained control may require setting specific permissions directly.
2.5.2 Inheritance Rules & Evaluation Precedence
NTFS inheritance allows parent ACEs to apply to children, controlled by ACE flags:
- OBJECT_INHERIT_ACE (OI): Inherited by files.
- CONTAINER_INHERIT_ACE (CI): Inherited by subdirectories.
- INHERIT_ONLY_ACE (IO): Applies only to children, not self.
- NO_PROPAGATE_INHERIT_ACE (NP): Inherited by immediate children only.
When an object is created, inheritable ACEs from the parent are copied to the child's SD, marked as inherited (INHERITED_ACE flag), and flags adjusted. Evaluation follows canonical order (Explicit Deny > Explicit Allow > Inherited Deny > Inherited Allow), with Deny overriding Allow.
2.5.3 Effective Permissions Calculation Process
Determining a user's effective permissions involves:
- Gather Subject Context: User SID, all relevant Group SIDs, enabled Privileges from Access Token.
- Retrieve Object Security: Get target file/folder's SD (Owner, DACL).
- Identify Applicable ACEs: Find all ACEs in DACL matching token SIDs. Categorize as Explicit Deny, Explicit Allow, Inherited Deny, Inherited Allow.
- Apply Precedence Rules: Simulate evaluation based on canonical order. Deny bits override Allow bits.
- Factor in Ownership/Privileges: Add implicit rights from ownership (READ_CONTROL,WRITE_DAC) and overrides from enabled privileges (SeBackupPrivilege, etc.).
- Result: The final computed access mask is the effective permission. Tools like the "Effective Access" tab automate this.
Complexity arises from multiple groups, inheritance, and deny ACEs.
2.5.4 On-Disk Storage (NTFS)
NTFS stores SDs efficiently:
- MFT Record: Contains attributes for each file/directory.
- $STANDARD_INFORMATIONAttribute: Holds Owner SID, flags.
- $SECURITY_DESCRIPTORAttribute: Holds security info.
- Resident Storage: Small SDs stored directly in the MFTrecord.
- Non-Resident Storage ($Secure::$SDSStream): Large or shared SDs stored in the global$Secure::$SDSstream. TheMFTattribute contains a reference (Security ID/hash+offset) to the data in$Secure::$SDS. This deduplication saves space and improves cache use.
Relevant for performance and forensics. Corruption here causes major access issues.
2.6 Modifying Security Descriptors (Permissions & Ownership)
2.6.1 Technical Sequence
Changing permissions (DACL), audit settings (SACL), or owner:
- User Action & Tool: User uses tool (Explorer,icacls.exe,PowerShell) to request SD change.
- Win32 API Call: Tool calls SetNamedSecurityInfoWorSetSecurityInfo, specifying object, what to change, and new SD data.
- API Layer Processing (advapi32.dll): Validates parameters, determines local/remote.
- RPC for Remote Objects: If remote, marshals parameters, calls RPC on target server (e.g., Server service) using caller's security context.
- Server-Side (or Local Kernel) Processing:
                    - Server receives request, impersonates client if remote.
- Access Check: Invokes SRM(SeSetSecurityObject) to check if caller's token has required rights on current SD:- Modify DACL: NeedsWRITE_DACor Ownership.
- Modify SACL: NeedsACCESS_SYSTEM_SECURITY(viaSeSecurityPrivilege).
- Change Owner: NeedsWRITE_OWNERorSeTakeOwnershipPrivilege(orSeRestorePrivilege).
 
- Modify 
- If check fails, return error (e.g., STATUS_ACCESS_DENIED).
- Object Security Update: If check succeeds, SRM/Object Managertells subsystem to update SD:- NTFS: Modifies- $SECURITY_DESCRIPTORattribute or- $Secure::$SDSstream via NTFS transaction.
- Registry: Configuration Manager updates key's SD in memory/hive file.
- AD: DSA modifies- nTSecurityDescriptorattribute in- NTDS.dit.
 
- Inheritance Propagation: If inheritable ACEs changed, kernel/subsystem may start background task to recursively update child SDs (with access checks).
 
- Return Status: Success/failure code returned to application.
2.6.2 Required Permissions/Privileges Summary
- Modify DACL:WRITE_DACorOwnership.
- Modify SACL:ACCESS_SYSTEM_SECURITY(viaSeSecurityPrivilege).
- Take Ownership:- SeTakeOwnershipPrivilege.
- Set Owner(arbitrary):- WRITE_OWNERor admin privileges (- SeRestorePrivilege).
2.6.3 Key Involved Components
- Client App (Explorer,icacls.exe, etc.)
- Win32 APIs (advapi32.dll,kernel32.dll)
- RPC Components
- Server Service (if remote)
- LSA(privilege checks)
- SRM(access check)
- Subsystem Drivers/Managers (ntfs.sys, Config Mgr,ntdsa.dll)
Modifying security is itself a privileged, controlled operation.
2.7 Summary of Involved Processes, Drivers, Services, Files, Memory Structures
Windows security relies on coordination between user-mode and kernel-mode components:
| Process Name | Typical Path | Primary Roles | 
|---|---|---|
| lsass.exe | %SystemRoot%\System32\ | LSA core, hosts Auth Pkgs, SAM logic, KDC/AD DS (DC), NetLogon, Token creation, policy enforcement, LSA Secrets. | 
| winlogon.exe | %SystemRoot%\System32\ | Interactive logon/logoff UI, SAS, credential capture coordination, launches user shell. | 
| services.exe | %SystemRoot%\System32\ | Service Control Manager (SCM). | 
| svchost.exe | %SystemRoot%\System32\ | Generic host for DLL-based services (RPCSS, Server service, etc.). | 
| System (ntoskrnl.exe) | N/A (Kernel Image) | Kernel/Executive. Hosts SRM, Object Manager, Config Manager (Registry), Memory/I/O Managers. | 
| User Applications | Various | Initiate access requests ( Explorer.exe,cmd.exe, etc.). | 
| Driver Name | Typical Path | Primary Roles | 
|---|---|---|
| ntfs.sys/refs.sys | %SystemRoot%\System32\drivers\ | File System Driver; manages on-disk structures (MFT, $Secure::$SDS); handles file object SDs; interacts with SRM. | 
| ksecdd.sys | %SystemRoot%\System32\drivers\ | Kerberos SSP kernel components. | 
| cng.sys | %SystemRoot%\System32\drivers\ | Cryptography API: Next Gen (CNG) kernel infrastructure. | 
| netlogon.sys | %SystemRoot%\System32\drivers\ | Kernel components for NetLogon secure channel. | 
| rdbss.sys/mrxsmb.sys | %SystemRoot%\System32\drivers\ | SMB client stack components. | 
| mup.sys | %SystemRoot%\System32\drivers\ | Multiple UNC Provider; routes network paths. | 
| Filter Drivers | Various | Intercept I/O; can enforce additional security (AV, EDR, DLP, etc.). | 
| Service Name | Service Display Name | Typical Hosting Process | Primary Roles | 
|---|---|---|---|
| SamSs | Security Accounts Manager | lsass.exe | Manages access to local SAM DB. | 
| Lsa (Implicit/Core) | Local Security Authority Subsystem | lsass.exe | Core functionality: authentication, tokens, policy. | 
| Kdc | Kerberos Key Distribution Center | lsass.exe (on DC) | Issues Kerberos tickets. | 
| Netlogon | Netlogon | lsass.exe | Maintains secure channel to DC, DC discovery, etc. | 
| RpcSs | Remote Procedure Call (RPC) | svchost.exe | Manages RPC endpoints and communication. | 
| LanmanServer / Srvsvc | Server | svchost.exe | Handles incoming SMB requests, file/print sharing. | 
| LanmanWorkstation / Workstation | Workstation | svchost.exe | SMB client functionality, outgoing connections. | 
| Item | Location | Description | 
|---|---|---|
| SAM Database | %SystemRoot%\System32\config\SAM | Hive storing local accounts/groups, cached credentials. | 
| SECURITY Hive | %SystemRoot%\System32\config\SECURITY | Hive storing LSA Secrets, cached policy. | 
| SYSTEM Hive | %SystemRoot%\System32\config\SYSTEM | Hive storing system config (LSA, services, drivers). | 
| AD Database | %SystemRoot%\NTDS\NTDS.dit (on DC) | ESE DB storing AD objects and attributes. | 
| MFT ($MFT) | NTFSVolume Root Metadata | Master File Table; contains file/dir records including $SECURITY_DESCRIPTORattribute. | 
| Secure Stream ($Secure::$SDS) | NTFSVolume Root Metadata | Stream storing shared/large SDs referenced from MFT. | 
| GPO Files (GPT) | \\ | Group Policy Template files (settings, scripts). | 
| Authentication Packages | %SystemRoot%\System32\ | DLLs loaded by LSA ( kerberos.dll,msv1_0.dll, etc.). | 
| Core Security APIs | %SystemRoot%\System32\ | DLLs providing security functions ( advapi32.dll,secur32.dll). | 
| Structure Name | Location | Description | 
|---|---|---|
| TOKENObject | Kernel Memory | Represents subject's security context (SIDs, Privileges). Managed by Object Manager/SRM. | 
| SECURITY_DESCRIPTOR | Kernel/User Memory | In-memory representation of object's security (Owner, DACL, SACL). Absolute or Self-Relative. | 
| LSA Policy Cache | lsass.exeMemory | Cached policy info (user rights, etc.) to optimize lookups. | 
| Kerberos Ticket Cache | lsass.exeMemory / User Session | Stores obtained Kerberos tickets (TGTs, Service Tickets). | 
| Credential Cache | lsass.exeMemory | Stores credential material (hashes, keys) for auth/network access. Protected by LSA. | 
This highlights the central roles of lsass.exe and ntoskrnl.exe, the importance of storage like SAM, NTDS.dit, and NTFS metadata, and the reliance on protocols like Kerberos and RPC. System security depends on the integrity and interaction of these components.
