 
        // wdm.h
NTSTATUS SeAssignSecurity(
  [in, optional] PSECURITY_DESCRIPTOR      ParentDescriptor,
  [in, optional] PSECURITY_DESCRIPTOR      ExplicitDescriptor,
  [out]          PSECURITY_DESCRIPTOR      *NewDescriptor,
  [in]           BOOLEAN                   IsDirectoryObject,
  [in]           PSECURITY_SUBJECT_CONTEXT SubjectContext,
  [in]           PGENERIC_MAPPING          GenericMapping,
  [in]           POOL_TYPE                 PoolType
);
View the official Windows Driver Kit DDI referenceNo description available.
The SeAssignSecurity routine builds a self-relative security descriptor for a new object, given the security descriptor of its parent directory and any originally requested security for the object.
ParentDescriptor [in, optional]Pointer to a buffer containing the SECURITY_DESCRIPTOR for the parent directory, if any, containing the new object being created. ParentDescriptor can be NULL, or have a NULL system access control list (SACL) or a NULL discretionary access control list (DACL).
ExplicitDescriptor [in, optional]Pointer to a buffer containing the SECURITY_DESCRIPTOR specified by the user that is applied to the new object. ExplicitDescriptor can be NULL, or have a NULL SACL or a NULL DACL.
NewDescriptor [out]Receives a pointer to the returned SECURITY_DESCRIPTOR. SeAssignSecurity allocates the buffer from the paged memory pool.
IsDirectoryObject [in]Specifies whether the new object is a directory object. TRUE indicates the object contains other objects.
SubjectContext [in]Pointer to a buffer containing the security context of the subject creating the object. This is used to retrieve default security information for the new object, such as the default owner, the primary group, and discretionary access control.
GenericMapping [in]Pointer to the GENERIC_MAPPING structure that describes the mapping from each generic right to the implied nongeneric rights.
PoolType [in]This parameter is unused. The buffer to hold the new security descriptor is always allocated from paged pool.
SeAssignSecurity can return one of the following:
| Return code | Description | 
|---|---|
| STATUS_SUCCESS | The assignment was successful. | 
| STATUS_INVALID_OWNER | The SID provided for the owner of the target security descriptor is not one the caller is authorized to assign as the owner of an object. | 
| STATUS_PRIVILEGE_NOT_HELD | The caller does not have the privilege (SeSecurityPrivilege) necessary to explicitly assign the specified system ACL. | 
The final security descriptor returned to the caller may contain a mix of information, some explicitly provided from the new object's parent.
SeAssignSecurity assumes privilege checking has not been performed. This routine performs privilege checking.
The assignment of system and discretionary ACLs is governed by the logic illustrated in the following table:
| Explicit (nondefault) ACL specified | Explicit default ACL specified | No ACL specified | |
|---|---|---|---|
| Inheritable ACL from parent | Assign specified ACL | Assign inherited ACL | Assign inherited ACL | 
| No inheritable ACL from parent | Assign specified ACL | Assign default ACL | Assign no ACL | 
An explicitly specified ACL, whether a default ACL or not, can be empty or null. The caller must be a kernel-mode client or be appropriately privileged to explicitly assign a default or nondefault system ACL.
The assignment of the new object's owner and group is governed by the following logic: