Revision control
Copy as Markdown
Other Tools
// Licensed under the Apache License, Version 2.0
// All files in the project carrying such notice may not be copied, modified, or distributed
// except according to those terms.
use shared::basetsd::SIZE_T;
use shared::minwindef::{BOOL, DWORD, PULONG, UCHAR};
use um::winnt::{LPCSTR, LPCWSTR, LPSTR, LPWSTR, PSECURITY_DESCRIPTOR, PSID, SECURITY_INFORMATION};
pub const SDDL_REVISION_1: UCHAR = 1;
pub const SDDL_REVISION: UCHAR = SDDL_REVISION_1;
pub const SDDL_OWNER: &'static str = "O";
pub const SDDL_GROUP: &'static str = "G";
pub const SDDL_DACL: &'static str = "D";
pub const SDDL_SACL: &'static str = "S";
pub const SDDL_PROTECTED: &'static str = "P";
pub const SDDL_AUTO_INHERIT_REQ: &'static str = "AR";
pub const SDDL_AUTO_INHERITED: &'static str = "AI";
pub const SDDL_NULL_ACL: &'static str = "NO_ACCESS_CONTROL";
pub const SDDL_ACCESS_ALLOWED: &'static str = "A";
pub const SDDL_ACCESS_DENIED: &'static str = "D";
pub const SDDL_OBJECT_ACCESS_ALLOWED: &'static str = "OA";
pub const SDDL_OBJECT_ACCESS_DENIED: &'static str = "OD";
pub const SDDL_AUDIT: &'static str = "AU";
pub const SDDL_ALARM: &'static str = "AL";
pub const SDDL_OBJECT_AUDIT: &'static str = "OU";
pub const SDDL_OBJECT_ALARM: &'static str = "OL";
pub const SDDL_MANDATORY_LABEL: &'static str = "ML";
pub const SDDL_PROCESS_TRUST_LABEL: &'static str = "TL";
pub const SDDL_CALLBACK_ACCESS_ALLOWED: &'static str = "XA";
pub const SDDL_CALLBACK_ACCESS_DENIED: &'static str = "XD";
pub const SDDL_RESOURCE_ATTRIBUTE: &'static str = "RA";
pub const SDDL_SCOPED_POLICY_ID: &'static str = "SP";
pub const SDDL_CALLBACK_AUDIT: &'static str = "XU";
pub const SDDL_CALLBACK_OBJECT_ACCESS_ALLOWED: &'static str = "ZA";
pub const SDDL_ACCESS_FILTER: &'static str = "FL";
pub const SDDL_INT: &'static str = "TI";
pub const SDDL_UINT: &'static str = "TU";
pub const SDDL_WSTRING: &'static str = "TS";
pub const SDDL_SID: &'static str = "TD";
pub const SDDL_BLOB: &'static str = "TX";
pub const SDDL_BOOLEAN: &'static str = "TB";
pub const SDDL_CONTAINER_INHERIT: &'static str = "CI";
pub const SDDL_OBJECT_INHERIT: &'static str = "OI";
pub const SDDL_NO_PROPAGATE: &'static str = "NP";
pub const SDDL_INHERIT_ONLY: &'static str = "IO";
pub const SDDL_INHERITED: &'static str = "ID";
pub const SDDL_TRUST_PROTECTED_FILTER: &'static str = "TP";
pub const SDDL_AUDIT_SUCCESS: &'static str = "SA";
pub const SDDL_AUDIT_FAILURE: &'static str = "FA";
pub const SDDL_READ_PROPERTY: &'static str = "RP";
pub const SDDL_WRITE_PROPERTY: &'static str = "WP";
pub const SDDL_CREATE_CHILD: &'static str = "CC";
pub const SDDL_DELETE_CHILD: &'static str = "DC";
pub const SDDL_LIST_CHILDREN: &'static str = "LC";
pub const SDDL_SELF_WRITE: &'static str = "SW";
pub const SDDL_LIST_OBJECT: &'static str = "LO";
pub const SDDL_DELETE_TREE: &'static str = "DT";
pub const SDDL_CONTROL_ACCESS: &'static str = "CR";
pub const SDDL_READ_CONTROL: &'static str = "RC";
pub const SDDL_WRITE_DAC: &'static str = "WD";
pub const SDDL_WRITE_OWNER: &'static str = "WO";
pub const SDDL_STANDARD_DELETE: &'static str = "SD";
pub const SDDL_GENERIC_ALL: &'static str = "GA";
pub const SDDL_GENERIC_READ: &'static str = "GR";
pub const SDDL_GENERIC_WRITE: &'static str = "GW";
pub const SDDL_GENERIC_EXECUTE: &'static str = "GX";
pub const SDDL_FILE_ALL: &'static str = "FA";
pub const SDDL_FILE_READ: &'static str = "FR";
pub const SDDL_FILE_WRITE: &'static str = "FW";
pub const SDDL_FILE_EXECUTE: &'static str = "FX";
pub const SDDL_KEY_ALL: &'static str = "KA";
pub const SDDL_KEY_READ: &'static str = "KR";
pub const SDDL_KEY_WRITE: &'static str = "KW";
pub const SDDL_KEY_EXECUTE: &'static str = "KX";
pub const SDDL_NO_WRITE_UP: &'static str = "NW";
pub const SDDL_NO_READ_UP: &'static str = "NR";
pub const SDDL_NO_EXECUTE_UP: &'static str = "NX";
pub const SDDL_ALIAS_SIZE: SIZE_T = 2;
pub const SDDL_DOMAIN_ADMINISTRATORS: &'static str = "DA";
pub const SDDL_DOMAIN_GUESTS: &'static str = "DG";
pub const SDDL_DOMAIN_USERS: &'static str = "DU";
pub const SDDL_ENTERPRISE_DOMAIN_CONTROLLERS: &'static str = "ED";
pub const SDDL_DOMAIN_DOMAIN_CONTROLLERS: &'static str = "DD";
pub const SDDL_DOMAIN_COMPUTERS: &'static str = "DC";
pub const SDDL_BUILTIN_ADMINISTRATORS: &'static str = "BA";
pub const SDDL_BUILTIN_GUESTS: &'static str = "BG";
pub const SDDL_BUILTIN_USERS: &'static str = "BU";
pub const SDDL_LOCAL_ADMIN: &'static str = "LA";
pub const SDDL_LOCAL_GUEST: &'static str = "LG";
pub const SDDL_ACCOUNT_OPERATORS: &'static str = "AO";
pub const SDDL_BACKUP_OPERATORS: &'static str = "BO";
pub const SDDL_PRINTER_OPERATORS: &'static str = "PO";
pub const SDDL_SERVER_OPERATORS: &'static str = "SO";
pub const SDDL_AUTHENTICATED_USERS: &'static str = "AU";
pub const SDDL_PERSONAL_SELF: &'static str = "PS";
pub const SDDL_CREATOR_OWNER: &'static str = "CO";
pub const SDDL_CREATOR_GROUP: &'static str = "CG";
pub const SDDL_LOCAL_SYSTEM: &'static str = "SY";
pub const SDDL_POWER_USERS: &'static str = "PU";
pub const SDDL_EVERYONE: &'static str = "WD";
pub const SDDL_REPLICATOR: &'static str = "RE";
pub const SDDL_INTERACTIVE: &'static str = "IU";
pub const SDDL_NETWORK: &'static str = "NU";
pub const SDDL_SERVICE: &'static str = "SU";
pub const SDDL_RESTRICTED_CODE: &'static str = "RC";
pub const SDDL_WRITE_RESTRICTED_CODE: &'static str = "WR";
pub const SDDL_ANONYMOUS: &'static str = "AN";
pub const SDDL_SCHEMA_ADMINISTRATORS: &'static str = "SA";
pub const SDDL_CERT_SERV_ADMINISTRATORS: &'static str = "CA";
pub const SDDL_RAS_SERVERS: &'static str = "RS";
pub const SDDL_ENTERPRISE_ADMINS: &'static str = "EA";
pub const SDDL_GROUP_POLICY_ADMINS: &'static str = "PA";
pub const SDDL_ALIAS_PREW2KCOMPACC: &'static str = "RU";
pub const SDDL_LOCAL_SERVICE: &'static str = "LS";
pub const SDDL_NETWORK_SERVICE: &'static str = "NS";
pub const SDDL_REMOTE_DESKTOP: &'static str = "RD";
pub const SDDL_NETWORK_CONFIGURATION_OPS: &'static str = "NO";
pub const SDDL_PERFMON_USERS: &'static str = "MU";
pub const SDDL_PERFLOG_USERS: &'static str = "LU";
pub const SDDL_IIS_USERS: &'static str = "IS";
pub const SDDL_CRYPTO_OPERATORS: &'static str = "CY";
pub const SDDL_OWNER_RIGHTS: &'static str = "OW";
pub const SDDL_EVENT_LOG_READERS: &'static str = "ER";
pub const SDDL_ENTERPRISE_RO_DCs: &'static str = "RO";
pub const SDDL_CERTSVC_DCOM_ACCESS: &'static str = "CD";
pub const SDDL_ALL_APP_PACKAGES: &'static str = "AC";
pub const SDDL_RDS_REMOTE_ACCESS_SERVERS: &'static str = "RA";
pub const SDDL_RDS_ENDPOINT_SERVERS: &'static str = "ES";
pub const SDDL_RDS_MANAGEMENT_SERVERS: &'static str = "MS";
pub const SDDL_USER_MODE_DRIVERS: &'static str = "UD";
pub const SDDL_HYPER_V_ADMINS: &'static str = "HA";
pub const SDDL_CLONEABLE_CONTROLLERS: &'static str = "CN";
pub const SDDL_ACCESS_CONTROL_ASSISTANCE_OPS: &'static str = "AA";
pub const SDDL_REMOTE_MANAGEMENT_USERS: &'static str = "RM";
pub const SDDL_AUTHORITY_ASSERTED: &'static str = "AS";
pub const SDDL_SERVICE_ASSERTED: &'static str = "SS";
pub const SDDL_PROTECTED_USERS: &'static str = "AP";
pub const SDDL_KEY_ADMINS: &'static str = "KA";
pub const SDDL_ENTERPRISE_KEY_ADMINS: &'static str = "EK";
pub const SDDL_ML_LOW: &'static str = "LW";
pub const SDDL_ML_MEDIUM: &'static str = "ME";
pub const SDDL_ML_MEDIUM_PLUS: &'static str = "MP";
pub const SDDL_ML_HIGH: &'static str = "HI";
pub const SDDL_ML_SYSTEM: &'static str = "SI";
pub const SDDL_SEPERATORC: char = ';';
pub const SDDL_DELIMINATORC: char = ':';
pub const SDDL_ACE_BEGINC: char = '(';
pub const SDDL_ACE_ENDC: char = ')';
pub const SDDL_SPACEC: char = ' ';
pub const SDDL_ACE_COND_BEGINC: char = '(';
pub const SDDL_ACE_COND_ENDC: char = ')';
pub const SDDL_ACE_COND_STRING_BEGINC: char = '"';
pub const SDDL_ACE_COND_STRING_ENDC: char = '"';
pub const SDDL_ACE_COND_COMPOSITEVALUE_BEGINC: char = '{';
pub const SDDL_ACE_COND_COMPOSITEVALUE_ENDC: char = '}';
pub const SDDL_ACE_COND_COMPOSITEVALUE_SEPERATORC: char = ',';
pub const SDDL_ACE_COND_BLOB_PREFIXC: char = '#';
pub const SDDL_ACE_COND_SID_BEGINC: char = '(';
pub const SDDL_ACE_COND_SID_ENDC: char = ')';
pub const SDDL_SEPERATOR: &'static str = ";";
pub const SDDL_DELIMINATOR: &'static str = ":";
pub const SDDL_ACE_BEGIN: &'static str = "(";
pub const SDDL_ACE_END: &'static str = ")";
pub const SDDL_ACE_COND_BEGIN: &'static str = "(";
pub const SDDL_ACE_COND_END: &'static str = ")";
pub const SDDL_SPACE: &'static str = " ";
pub const SDDL_ACE_COND_BLOB_PREFIX: &'static str = "#";
pub const SDDL_ACE_COND_SID_PREFIX: &'static str = "SID";
pub const SDDL_ACE_COND_ATTRIBUTE_PREFIX: &'static str = "@";
pub const SDDL_ACE_COND_USER_ATTRIBUTE_PREFIX: &'static str = "@USER.";
pub const SDDL_ACE_COND_RESOURCE_ATTRIBUTE_PREFIX: &'static str = "@RESOURCE.";
pub const SDDL_ACE_COND_DEVICE_ATTRIBUTE_PREFIX: &'static str = "@DEVICE.";
pub const SDDL_ACE_COND_TOKEN_ATTRIBUTE_PREFIX: &'static str = "@TOKEN.";
extern "system" {
pub fn ConvertSidToStringSidA(
Sid: PSID,
StringSid: *mut LPSTR,
) -> BOOL;
pub fn ConvertSidToStringSidW(
Sid: PSID,
StringSid: *mut LPWSTR,
) -> BOOL;
pub fn ConvertStringSidToSidA(
StringSid: LPCSTR,
Sid: *mut PSID,
) -> BOOL;
pub fn ConvertStringSidToSidW(
StringSid: LPCWSTR,
Sid: *mut PSID,
) -> BOOL;
pub fn ConvertStringSecurityDescriptorToSecurityDescriptorA(
StringSecurityDescriptor: LPCSTR,
StringSDRevision: DWORD,
SecurityDescriptor: *mut PSECURITY_DESCRIPTOR,
SecurityDescriptorSize: PULONG,
) -> BOOL;
pub fn ConvertStringSecurityDescriptorToSecurityDescriptorW(
StringSecurityDescriptor: LPCWSTR,
StringSDRevision: DWORD,
SecurityDescriptor: *mut PSECURITY_DESCRIPTOR,
SecurityDescriptorSize: PULONG,
) -> BOOL;
pub fn ConvertSecurityDescriptorToStringSecurityDescriptorA(
SecurityDescriptor: PSECURITY_DESCRIPTOR,
RequestedStringSDRevision: DWORD,
SecurityInformation: SECURITY_INFORMATION,
StringSecurityDescriptor: *mut LPSTR,
StringSecurityDescriptorLen: PULONG,
) -> BOOL;
pub fn ConvertSecurityDescriptorToStringSecurityDescriptorW(
SecurityDescriptor: PSECURITY_DESCRIPTOR,
RequestedStringSDRevision: DWORD,
SecurityInformation: SECURITY_INFORMATION,
StringSecurityDescriptor: *mut LPWSTR,
StringSecurityDescriptorLen: PULONG,
) -> BOOL;
}