|
|
//+--------------------------------------------------------------------------- // // Microsoft Windows // Copyright (C) Microsoft Corporation, 1992-1999. // // File: winefs.h // // Contents: EFS Data and prototypes. // //----------------------------------------------------------------------------
#ifndef __WINEFS_H__ #define __WINEFS_H__
#if _MSC_VER > 1000 #pragma once #endif
#ifdef __cplusplus extern "C" { #endif
//+---------------------------------------------------------------------------------/ // / // / // Data Structures / // / // / //----------------------------------------------------------------------------------/
#ifndef ALGIDDEF #define ALGIDDEF typedef unsigned int ALG_ID; #endif
// // Encoded Certificate //
typedef struct _CERTIFICATE_BLOB {
DWORD dwCertEncodingType;
#ifdef MIDL_PASS [range(0,32768)] #endif // MIDL_PASS
DWORD cbData;
#ifdef MIDL_PASS [size_is(cbData)] #endif // MIDL_PASS PBYTE pbData;
} EFS_CERTIFICATE_BLOB, *PEFS_CERTIFICATE_BLOB;
// // Certificate Hash //
typedef struct _EFS_HASH_BLOB {
#ifdef MIDL_PASS [range(0,100)] #endif // MIDL_PASS DWORD cbData;
#ifdef MIDL_PASS [size_is(cbData)] #endif // MIDL_PASS PBYTE pbData;
} EFS_HASH_BLOB, *PEFS_HASH_BLOB;
// // RPC blob //
typedef struct _EFS_RPC_BLOB {
#ifdef MIDL_PASS [range(0,266240)] #endif // MIDL_PASS DWORD cbData;
#ifdef MIDL_PASS [size_is(cbData)] #endif // MIDL_PASS PBYTE pbData;
} EFS_RPC_BLOB, *PEFS_RPC_BLOB;
typedef struct _EFS_KEY_INFO {
DWORD dwVersion; ULONG Entropy; ALG_ID Algorithm; ULONG KeyLength; } EFS_KEY_INFO, *PEFS_KEY_INFO;
// // Input to add a user to an encrypted file //
typedef struct _ENCRYPTION_CERTIFICATE { DWORD cbTotalLength; SID * pUserSid; PEFS_CERTIFICATE_BLOB pCertBlob; } ENCRYPTION_CERTIFICATE, *PENCRYPTION_CERTIFICATE;
#define MAX_SID_SIZE 256
typedef struct _ENCRYPTION_CERTIFICATE_HASH { DWORD cbTotalLength; SID * pUserSid; PEFS_HASH_BLOB pHash;
#ifdef MIDL_PASS [string] #endif // MIDL_PASS LPWSTR lpDisplayInformation;
} ENCRYPTION_CERTIFICATE_HASH, *PENCRYPTION_CERTIFICATE_HASH;
typedef struct _ENCRYPTION_CERTIFICATE_HASH_LIST { #ifdef MIDL_PASS [range(0,500)] #endif // MIDL_PASS DWORD nCert_Hash; #ifdef MIDL_PASS [size_is(nCert_Hash)] #endif // MIDL_PASS PENCRYPTION_CERTIFICATE_HASH * pUsers; } ENCRYPTION_CERTIFICATE_HASH_LIST, *PENCRYPTION_CERTIFICATE_HASH_LIST;
typedef struct _ENCRYPTION_CERTIFICATE_LIST { #ifdef MIDL_PASS [range(0,500)] #endif // MIDL_PASS DWORD nUsers; #ifdef MIDL_PASS [size_is(nUsers)] #endif // MIDL_PASS PENCRYPTION_CERTIFICATE * pUsers; } ENCRYPTION_CERTIFICATE_LIST, *PENCRYPTION_CERTIFICATE_LIST;
//+---------------------------------------------------------------------------------/ // / // / // Prototypes / // / // / //----------------------------------------------------------------------------------/
WINADVAPI DWORD WINAPI QueryUsersOnEncryptedFile( IN LPCWSTR lpFileName, OUT PENCRYPTION_CERTIFICATE_HASH_LIST * pUsers );
WINADVAPI DWORD WINAPI QueryRecoveryAgentsOnEncryptedFile( IN LPCWSTR lpFileName, OUT PENCRYPTION_CERTIFICATE_HASH_LIST * pRecoveryAgents );
WINADVAPI DWORD WINAPI RemoveUsersFromEncryptedFile( IN LPCWSTR lpFileName, IN PENCRYPTION_CERTIFICATE_HASH_LIST pHashes );
WINADVAPI DWORD WINAPI AddUsersToEncryptedFile( IN LPCWSTR lpFileName, IN PENCRYPTION_CERTIFICATE_LIST pUsers );
WINADVAPI DWORD WINAPI SetUserFileEncryptionKey( IN PENCRYPTION_CERTIFICATE pEncryptionCertificate );
WINADVAPI VOID WINAPI FreeEncryptionCertificateHashList( IN PENCRYPTION_CERTIFICATE_HASH_LIST pHashes );
WINADVAPI BOOL WINAPI EncryptionDisable( IN LPCWSTR DirPath, IN BOOL Disable );
WINADVAPI DWORD WINAPI DuplicateEncryptionInfoFile( IN LPCWSTR SrcFileName, IN LPCWSTR DstFileName, IN DWORD dwCreationDistribution, IN DWORD dwAttributes, IN CONST LPSECURITY_ATTRIBUTES lpSecurityAttributes );
#ifdef __cplusplus } // Balance extern "C" above #endif
#endif // __WINEFS_H__
|