blob: af98bd928d93923fa5e84e87d56beaef7e275e1a [file] [log] [blame] [edit]
// Copyright © 2015, Peter Atashian
// Licensed under the MIT License <LICENSE.md>
//! Authentication API Prototypes and Definitions
pub const NERR_BASE: ::DWORD = 2100;
pub const NERR_PasswordExpired: ::DWORD = NERR_BASE+142;
pub const CRED_MAX_STRING_LENGTH: ::DWORD = 256;
pub const CRED_MAX_USERNAME_LENGTH: ::DWORD = 256+1+256;
pub const CRED_MAX_GENERIC_TARGET_NAME_LENGTH: ::DWORD = 32767;
pub const CRED_MAX_DOMAIN_TARGET_NAME_LENGTH: ::DWORD = 256+1+80;
pub const CRED_MAX_TARGETNAME_NAMESPACE_LENGTH: ::DWORD = 256;
pub const CRED_MAX_TARGETNAME_ATTRIBUTE_LENGTH: ::DWORD = 256;
pub const CRED_MAX_VALUE_SIZE: ::DWORD = 256;
pub const CRED_MAX_ATTRIBUTES: ::DWORD = 64;
pub const CRED_LOGON_TYPES_MASK: ::DWORD = 0xF000;
pub const CRED_FLAGS_PASSWORD_FOR_CERT: ::DWORD = 0x0001;
pub const CRED_FLAGS_PROMPT_NOW: ::DWORD = 0x0002;
pub const CRED_FLAGS_USERNAME_TARGET: ::DWORD = 0x0004;
pub const CRED_FLAGS_OWF_CRED_BLOB: ::DWORD = 0x0008;
pub const CRED_FLAGS_REQUIRE_CONFIRMATION: ::DWORD = 0x0010;
pub const CRED_FLAGS_WILDCARD_MATCH: ::DWORD = 0x0020;
pub const CRED_FLAGS_VALID_FLAGS: ::DWORD = 0xF03F;
pub const CRED_FLAGS_VALID_INPUT_FLAGS: ::DWORD = 0xF01F;
pub const CRED_TYPE_GENERIC: ::DWORD = 1;
pub const CRED_TYPE_DOMAIN_PASSWORD: ::DWORD = 2;
pub const CRED_TYPE_DOMAIN_CERTIFICATE: ::DWORD = 3;
pub const CRED_TYPE_DOMAIN_VISIBLE_PASSWORD: ::DWORD = 4;
pub const CRED_TYPE_GENERIC_CERTIFICATE: ::DWORD = 5;
pub const CRED_TYPE_DOMAIN_EXTENDED: ::DWORD = 6;
pub const CRED_TYPE_MAXIMUM: ::DWORD = 7;
pub const CRED_TYPE_MAXIMUM_EX: ::DWORD = CRED_TYPE_MAXIMUM+1000;
pub const CRED_MAX_CREDENTIAL_BLOB_SIZE: ::DWORD = 5*512;
pub const CRED_PERSIST_NONE: ::DWORD = 0;
pub const CRED_PERSIST_SESSION: ::DWORD = 1;
pub const CRED_PERSIST_LOCAL_MACHINE: ::DWORD = 2;
pub const CRED_PERSIST_ENTERPRISE: ::DWORD = 3;
STRUCT!{struct CREDENTIAL_ATTRIBUTEA {
Keyword: ::LPSTR,
Flags: ::DWORD,
ValueSize: ::DWORD,
Value: ::LPBYTE,
}}
pub type PCREDENTIAL_ATTRIBUTEA = *mut CREDENTIAL_ATTRIBUTEA;
STRUCT!{struct CREDENTIAL_ATTRIBUTEW {
Keyword: ::LPWSTR,
Flags: ::DWORD,
ValueSize: ::DWORD,
Value: ::LPBYTE,
}}
pub type PCREDENTIAL_ATTRIBUTEW = *mut CREDENTIAL_ATTRIBUTEW;
STRUCT!{struct CREDENTIALA {
Flags: ::DWORD,
Type: ::DWORD,
TargetName: ::LPSTR,
Comment: ::LPSTR,
LastWritten: ::FILETIME,
CredentialBlobSize: ::DWORD,
CredentialBlob: ::LPBYTE,
Persist: ::DWORD,
AttributeCount: ::DWORD,
Attributes: PCREDENTIAL_ATTRIBUTEA,
TargetAlias: ::LPSTR,
UserName: ::LPSTR,
}}
pub type PCREDENTIALA = *mut CREDENTIALA;
STRUCT!{struct CREDENTIALW {
Flags: ::DWORD,
Type: ::DWORD,
TargetName: ::LPWSTR,
Comment: ::LPWSTR,
LastWritten: ::FILETIME,
CredentialBlobSize: ::DWORD,
CredentialBlob: ::LPBYTE,
Persist: ::DWORD,
AttributeCount: ::DWORD,
Attributes: PCREDENTIAL_ATTRIBUTEW,
TargetAlias: ::LPWSTR,
UserName: ::LPWSTR,
}}
pub type PCREDENTIALW = *mut CREDENTIALW;
pub const CRED_TI_SERVER_FORMAT_UNKNOWN: ::ULONG = 0x0001;
pub const CRED_TI_DOMAIN_FORMAT_UNKNOWN: ::ULONG = 0x0002;
pub const CRED_TI_ONLY_PASSWORD_REQUIRED: ::ULONG = 0x0004;
pub const CRED_TI_USERNAME_TARGET: ::ULONG = 0x0008;
pub const CRED_TI_CREATE_EXPLICIT_CRED: ::ULONG = 0x0010;
pub const CRED_TI_WORKGROUP_MEMBER: ::ULONG = 0x0020;
pub const CRED_TI_VALID_FLAGS: ::ULONG = 0xF07F;
STRUCT!{struct CREDENTIAL_TARGET_INFORMATIONA {
TargetName: ::LPSTR,
NetbiosServerName: ::LPSTR,
DnsServerName: ::LPSTR,
NetbiosDomainName: ::LPSTR,
DnsDomainName: ::LPSTR,
DnsTreeName: ::LPSTR,
PackageName: ::LPSTR,
Flags: ::ULONG,
CredTypeCount: ::DWORD,
CredTypes: ::LPDWORD,
}}
pub type PCREDENTIAL_TARGET_INFORMATIONA = *mut CREDENTIAL_TARGET_INFORMATIONA;
STRUCT!{struct CREDENTIAL_TARGET_INFORMATIONW {
TargetName: ::LPWSTR,
NetbiosServerName: ::LPWSTR,
DnsServerName: ::LPWSTR,
NetbiosDomainName: ::LPWSTR,
DnsDomainName: ::LPWSTR,
DnsTreeName: ::LPWSTR,
PackageName: ::LPWSTR,
Flags: ::ULONG,
CredTypeCount: ::DWORD,
CredTypes: ::LPDWORD,
}}
pub type PCREDENTIAL_TARGET_INFORMATIONW = *mut CREDENTIAL_TARGET_INFORMATIONW;
pub const CERT_HASH_LENGTH: usize = 20;
STRUCT!{struct CERT_CREDENTIAL_INFO {
cbSize: ::ULONG,
rgbHashOfCert: [::UCHAR; CERT_HASH_LENGTH],
}}
pub type PCERT_CREDENTIAL_INFO = *mut CERT_CREDENTIAL_INFO;
STRUCT!{struct USERNAME_TARGET_CREDENTIAL_INFO {
UserName: ::LPWSTR,
}}
pub type PUSERNAME_TARGET_CREDENTIAL_INFO = *mut USERNAME_TARGET_CREDENTIAL_INFO;
STRUCT!{struct BINARY_BLOB_CREDENTIAL_INFO {
cbBlob: ::ULONG,
pbBlob: ::LPBYTE,
}}
pub type PBINARY_BLOB_CREDENTIAL_INFO = *mut BINARY_BLOB_CREDENTIAL_INFO;
ENUM!{enum CRED_MARSHAL_TYPE {
CertCredential = 1,
UsernameTargetCredential,
BinaryBlobCredential,
UsernameForPackedCredentials,
}}
pub type PCRED_MARSHAL_TYPE = *mut CRED_MARSHAL_TYPE;
ENUM!{enum CRED_PROTECTION_TYPE {
CredUnprotected,
CredUserProtection,
CredTrustedProtection,
}}
pub type PCRED_PROTECTION_TYPE = *mut CRED_PROTECTION_TYPE;
pub const CRED_PACK_PROTECTED_CREDENTIALS: ::DWORD = 0x1;
pub const CRED_PACK_WOW_BUFFER: ::DWORD = 0x2;
pub const CRED_PACK_GENERIC_CREDENTIALS: ::DWORD = 0x4;
pub const CRED_PACK_ID_PROVIDER_CREDENTIALS: ::DWORD = 0x8;
STRUCT!{struct CREDUI_INFOA {
cbSize: ::DWORD,
hwndParent: ::HWND,
pszMessageText: ::PCSTR,
pszCaptionText: ::PCSTR,
hbmBanner: ::HBITMAP,
}}
pub type PCREDUI_INFOA = *mut CREDUI_INFOA;
STRUCT!{struct CREDUI_INFOW {
cbSize: ::DWORD,
hwndParent: ::HWND,
pszMessageText: ::PCWSTR,
pszCaptionText: ::PCWSTR,
hbmBanner: ::HBITMAP,
}}
pub type PCREDUI_INFOW = *mut CREDUI_INFOW;
pub const CREDUI_MAX_MESSAGE_LENGTH: ::DWORD = 1024;
pub const CREDUI_MAX_CAPTION_LENGTH: ::DWORD = 128;
pub const CREDUI_MAX_GENERIC_TARGET_LENGTH: ::DWORD = CRED_MAX_GENERIC_TARGET_NAME_LENGTH;
pub const CREDUI_MAX_DOMAIN_TARGET_LENGTH: ::DWORD = CRED_MAX_DOMAIN_TARGET_NAME_LENGTH;
pub const CREDUI_MAX_USERNAME_LENGTH: ::DWORD = CRED_MAX_USERNAME_LENGTH;
pub const CREDUI_MAX_PASSWORD_LENGTH: ::DWORD = 512 / 2;
pub const CREDUI_FLAGS_INCORRECT_PASSWORD: ::DWORD = 0x00001;
pub const CREDUI_FLAGS_DO_NOT_PERSIST: ::DWORD = 0x00002;
pub const CREDUI_FLAGS_REQUEST_ADMINISTRATOR: ::DWORD = 0x00004;
pub const CREDUI_FLAGS_EXCLUDE_CERTIFICATES: ::DWORD = 0x00008;
pub const CREDUI_FLAGS_REQUIRE_CERTIFICATE: ::DWORD = 0x00010;
pub const CREDUI_FLAGS_SHOW_SAVE_CHECK_BOX: ::DWORD = 0x00040;
pub const CREDUI_FLAGS_ALWAYS_SHOW_UI: ::DWORD = 0x00080;
pub const CREDUI_FLAGS_REQUIRE_SMARTCARD: ::DWORD = 0x00100;
pub const CREDUI_FLAGS_PASSWORD_ONLY_OK: ::DWORD = 0x00200;
pub const CREDUI_FLAGS_VALIDATE_USERNAME: ::DWORD = 0x00400;
pub const CREDUI_FLAGS_COMPLETE_USERNAME: ::DWORD = 0x00800;
pub const CREDUI_FLAGS_PERSIST: ::DWORD = 0x01000;
pub const CREDUI_FLAGS_SERVER_CREDENTIAL: ::DWORD = 0x04000;
pub const CREDUI_FLAGS_EXPECT_CONFIRMATION: ::DWORD = 0x20000;
pub const CREDUI_FLAGS_GENERIC_CREDENTIALS: ::DWORD = 0x40000;
pub const CREDUI_FLAGS_USERNAME_TARGET_CREDENTIALS: ::DWORD = 0x80000;
pub const CREDUI_FLAGS_KEEP_USERNAME: ::DWORD = 0x100000;
pub const CREDUI_FLAGS_PROMPT_VALID: ::DWORD = CREDUI_FLAGS_INCORRECT_PASSWORD
| CREDUI_FLAGS_DO_NOT_PERSIST | CREDUI_FLAGS_REQUEST_ADMINISTRATOR
| CREDUI_FLAGS_EXCLUDE_CERTIFICATES | CREDUI_FLAGS_REQUIRE_CERTIFICATE
| CREDUI_FLAGS_SHOW_SAVE_CHECK_BOX | CREDUI_FLAGS_ALWAYS_SHOW_UI
| CREDUI_FLAGS_REQUIRE_SMARTCARD | CREDUI_FLAGS_PASSWORD_ONLY_OK
| CREDUI_FLAGS_VALIDATE_USERNAME | CREDUI_FLAGS_COMPLETE_USERNAME | CREDUI_FLAGS_PERSIST
| CREDUI_FLAGS_SERVER_CREDENTIAL | CREDUI_FLAGS_EXPECT_CONFIRMATION
| CREDUI_FLAGS_GENERIC_CREDENTIALS | CREDUI_FLAGS_USERNAME_TARGET_CREDENTIALS
| CREDUI_FLAGS_KEEP_USERNAME;
pub const CREDUIWIN_GENERIC: ::DWORD = 0x00000001;
pub const CREDUIWIN_CHECKBOX: ::DWORD = 0x00000002;
pub const CREDUIWIN_AUTHPACKAGE_ONLY: ::DWORD = 0x00000010;
pub const CREDUIWIN_IN_CRED_ONLY: ::DWORD = 0x00000020;
pub const CREDUIWIN_ENUMERATE_ADMINS: ::DWORD = 0x00000100;
pub const CREDUIWIN_ENUMERATE_CURRENT_USER: ::DWORD = 0x00000200;
pub const CREDUIWIN_SECURE_PROMPT: ::DWORD = 0x00001000;
pub const CREDUIWIN_PREPROMPTING: ::DWORD = 0x00002000;
pub const CREDUIWIN_PACK_32_WOW: ::DWORD = 0x10000000;
pub const CREDUIWIN_VALID_FLAGS: ::DWORD = CREDUIWIN_GENERIC | CREDUIWIN_CHECKBOX
| CREDUIWIN_AUTHPACKAGE_ONLY | CREDUIWIN_IN_CRED_ONLY | CREDUIWIN_ENUMERATE_ADMINS
| CREDUIWIN_ENUMERATE_CURRENT_USER | CREDUIWIN_SECURE_PROMPT | CREDUIWIN_PREPROMPTING
| CREDUIWIN_PACK_32_WOW;
pub const CRED_PRESERVE_CREDENTIAL_BLOB: ::DWORD = 0x1;
pub const CRED_ENUMERATE_ALL_CREDENTIALS: ::DWORD = 0x1;
pub const CRED_CACHE_TARGET_INFORMATION: ::DWORD = 0x1;
pub const CRED_ALLOW_NAME_RESOLUTION: ::DWORD = 0x1;