|
|
// Group policy refresh named event signaled by our GPE when gp refreshes // without GP changes or without a forced refresh.
#define IPSEC_GP_REFRESH_EVENT L"IPSEC_GP_REFRESH_EVENT"
#define REG_IPSEC_DRIVER_STATEFULMODE 3
#define IPSEC_REGISTRY_PROVIDER 0 #define IPSEC_DIRECTORY_PROVIDER 1 #define IPSEC_FILE_PROVIDER 2 #define IPSEC_WMI_PROVIDER 3 #define IPSEC_PERSISTENT_PROVIDER 4
#define POLSTORE_READWRITE 0x00000000 #define POLSTORE_READONLY 0x00000001 #define POLSTORE_NEW_VER 0x00000002 #define POLSTORE_PARTIAL 0x00000004
#define POL_ACTION_ASSIGN 1 #define POL_ACTION_UNASSIGN 2
// // Structure for data interchange between Winlogon/Group Policy // and polstore (see RSOP_PolicySetting in MSDN) //
typedef struct _GPO_INFO { BSTR bsCreationtime; UINT32 uiPrecedence; BSTR bsGPOID; BSTR bsSOMID; UINT32 uiTotalGPOs; } GPO_INFO, *PGPO_INFO;
// // Extra RSOP information for objects stored in WMI store. //
typedef struct _RSOP_INFO { LPWSTR pszCreationtime; LPWSTR pszID; LPWSTR pszName; UINT32 uiPrecedence; LPWSTR pszGPOID; LPWSTR pszSOMID; } RSOP_INFO, * PRSOP_INFO;
typedef struct _IPSEC_AUTH_METHOD { DWORD dwAuthType; DWORD dwAuthLen; LPWSTR pszAuthMethod; DWORD dwAltAuthLen; PBYTE pAltAuthMethod; DWORD dwAuthFlags; } IPSEC_AUTH_METHOD, *PIPSEC_AUTH_METHOD;
typedef struct _IPSEC_FILTER_SPEC { LPWSTR pszSrcDNSName; LPWSTR pszDestDNSName; LPWSTR pszDescription; GUID FilterSpecGUID; DWORD dwMirrorFlag; IPSEC_FILTER Filter; } IPSEC_FILTER_SPEC, *PIPSEC_FILTER_SPEC;
typedef struct _IPSEC_FILTER_DATA { GUID FilterIdentifier; DWORD dwNumFilterSpecs; PIPSEC_FILTER_SPEC * ppFilterSpecs; DWORD dwWhenChanged; LPWSTR pszIpsecName; LPWSTR pszDescription; DWORD dwFlags; } IPSEC_FILTER_DATA, *PIPSEC_FILTER_DATA;
typedef IPSEC_ALG_TYPE IPSEC_SECURITY_METHOD, *PIPSEC_SECURITY_METHOD;
// Flags specific to security method
#define FALLBACK_NON_IPSEC_AWARE 0x1 #define FALLBACK_IKE_FAILURE 0x2
typedef struct _IPSEC_NEGPOL_DATA { GUID NegPolIdentifier; GUID NegPolAction; GUID NegPolType; DWORD dwSecurityMethodCount; IPSEC_SECURITY_METHOD * pIpsecSecurityMethods; DWORD dwWhenChanged; LPWSTR pszIpsecName; LPWSTR pszDescription; DWORD dwFlags; } IPSEC_NEGPOL_DATA, *PIPSEC_NEGPOL_DATA;
typedef struct _IPSEC_ISAKMP_DATA { GUID ISAKMPIdentifier; ISAKMP_POLICY ISAKMPPolicy; DWORD dwNumISAKMPSecurityMethods; PCRYPTO_BUNDLE pSecurityMethods; DWORD dwWhenChanged; DWORD dwFlags; } IPSEC_ISAKMP_DATA, *PIPSEC_ISAKMP_DATA;
typedef struct _IPSEC_NFA_DATA { LPWSTR pszIpsecName; GUID NFAIdentifier; DWORD dwAuthMethodCount; PIPSEC_AUTH_METHOD * ppAuthMethods; DWORD dwInterfaceType; LPWSTR pszInterfaceName; DWORD dwTunnelIpAddr; DWORD dwTunnelFlags; DWORD dwActiveFlag; LPWSTR pszEndPointName; PIPSEC_FILTER_DATA pIpsecFilterData; PIPSEC_NEGPOL_DATA pIpsecNegPolData; DWORD dwWhenChanged; GUID NegPolIdentifier; GUID FilterIdentifier; LPWSTR pszDescription; DWORD dwFlags; } IPSEC_NFA_DATA, *PIPSEC_NFA_DATA;
typedef struct _IPSEC_POLICY_DATA{ GUID PolicyIdentifier; DWORD dwPollingInterval; PIPSEC_ISAKMP_DATA pIpsecISAKMPData; PIPSEC_NFA_DATA * ppIpsecNFAData; DWORD dwNumNFACount; DWORD dwWhenChanged; LPWSTR pszIpsecName; LPWSTR pszDescription; GUID ISAKMPIdentifier; PRSOP_INFO pRsopInfo; DWORD dwFlags; } IPSEC_POLICY_DATA, *PIPSEC_POLICY_DATA;
LPVOID AllocPolMem( DWORD cb );
BOOL FreePolMem( LPVOID pMem );
LPWSTR AllocPolStr( LPCWSTR pStr );
BOOL FreePolStr( LPWSTR pStr );
DWORD ReallocatePolMem( LPVOID * ppOldMem, DWORD cbOld, DWORD cbNew );
BOOL ReallocPolStr( LPWSTR *ppStr, LPWSTR pStr );
void FreeIpsecPolicyData( PIPSEC_POLICY_DATA pIpsecPolicyData );
void FreeIpsecNegPolData( PIPSEC_NEGPOL_DATA pIpsecNegPolData );
void FreeIpsecFilterData( PIPSEC_FILTER_DATA pIpsecFilterData );
void FreeIpsecISAKMPData( PIPSEC_ISAKMP_DATA pIpsecISAKMPData );
void FreeIpsecNFAData( PIPSEC_NFA_DATA pIpsecNFAData );
DWORD CopyIpsecPolicyData( PIPSEC_POLICY_DATA pIpsecPolicyData, PIPSEC_POLICY_DATA * ppIpsecPolicyData );
DWORD CopyIpsecNFAData( PIPSEC_NFA_DATA pIpsecNFAData, PIPSEC_NFA_DATA * ppIpsecNFAData );
DWORD CopyIpsecAuthMethod( PIPSEC_AUTH_METHOD pAuthMethod, PIPSEC_AUTH_METHOD * ppAuthMethod );
DWORD CopyIpsecISAKMPData( PIPSEC_ISAKMP_DATA pIpsecISAKMPData, PIPSEC_ISAKMP_DATA * ppIpsecISAKMPData );
DWORD CopyIpsecFilterData( PIPSEC_FILTER_DATA pIpsecFilterData, PIPSEC_FILTER_DATA * ppIpsecFilterData );
DWORD CopyIpsecFilterSpec( PIPSEC_FILTER_SPEC pFilterSpecs, PIPSEC_FILTER_SPEC * ppFilterSpecs );
DWORD CopyIpsecNegPolData( PIPSEC_NEGPOL_DATA pIpsecNegPolData, PIPSEC_NEGPOL_DATA * ppIpsecNegPolData );
void FreeMulIpsecFilterData( PIPSEC_FILTER_DATA * ppIpsecFilterData, DWORD dwNumFilterObjects );
void FreeMulIpsecNegPolData( PIPSEC_NEGPOL_DATA * ppIpsecNegPolData, DWORD dwNumNegPolObjects );
void FreeMulIpsecPolicyData( PIPSEC_POLICY_DATA * ppIpsecPolicyData, DWORD dwNumPolicyObjects );
void FreeMulIpsecNFAData( PIPSEC_NFA_DATA * ppIpsecNFAData, DWORD dwNumNFAObjects );
void FreeIpsecFilterSpecs( PIPSEC_FILTER_SPEC * ppIpsecFilterSpecs, DWORD dwNumFilterSpecs );
void FreeIpsecFilterSpec( PIPSEC_FILTER_SPEC pIpsecFilterSpec );
void FreeMulIpsecISAKMPData( PIPSEC_ISAKMP_DATA * ppIpsecISAKMPData, DWORD dwNumISAKMPObjects );
|