????

Your IP : 3.144.101.157


Current Path : C:/opt/msys64/ucrt64/include/
Upload File :
Current File : C:/opt/msys64/ucrt64/include/iketypes.idl

cpp_quote("/**")
cpp_quote(" * This file is part of the mingw-w64 runtime package.")
cpp_quote(" * No warranty is given; refer to the file DISCLAIMER within this package.")
cpp_quote(" */")
cpp_quote("")
cpp_quote("#include <winapifamily.h>")
cpp_quote("#if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)")
cpp_quote("")

#include "winerror.h"
import "fwptypes.idl";


cpp_quote("#define IKEEXT_ERROR_CODE_COUNT (ERROR_IPSEC_IKE_NEG_STATUS_END - ERROR_IPSEC_IKE_NEG_STATUS_BEGIN)")
cpp_quote("")
cpp_quote("/* Please keep in sync with winerror.h defines.  */")
#define IKEEXT_ERROR_CODE_COUNT 97

cpp_quote("")

cpp_quote("#define IKEEXT_CERT_FLAG_ENABLE_ACCOUNT_MAPPING          (0x1)")
cpp_quote("#define IKEEXT_CERT_FLAG_DISABLE_REQUEST_PAYLOAD         (0x2)")
cpp_quote("#define IKEEXT_CERT_FLAG_USE_NAP_CERTIFICATE             (0x4)")
cpp_quote("#define IKEEXT_CERT_FLAG_INTERMEDIATE_CA                 (0x8)")
cpp_quote("#define IKEEXT_CERT_FLAG_IGNORE_INIT_CERT_MAP_FAILURE    (0x10)")
cpp_quote("#define IKEEXT_CERT_FLAG_PREFER_NAP_CERTIFICATE_OUTBOUND (0x20)")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
cpp_quote("#define IKEEXT_CERT_FLAG_SELECT_NAP_CERTIFICATE          (0x40)")
cpp_quote("#define IKEEXT_CERT_FLAG_VERIFY_NAP_CERTIFICATE          (0x80)")
cpp_quote("#define IKEEXT_CERT_FLAG_FOLLOW_RENEWAL_CERTIFICATE      (0x100)")
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#define IKEEXT_CERT_AUTH_FLAG_SSL_ONE_WAY            (0x1)")
cpp_quote("#define IKEEXT_CERT_AUTH_FLAG_DISABLE_CRL_CHECK      (0x2)")
cpp_quote("#define IKEEXT_CERT_AUTH_ENABLE_CRL_CHECK_STRONG     (0x4)")
cpp_quote("#define IKEEXT_CERT_AUTH_DISABLE_SSL_CERT_VALIDATION (0x8)")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
cpp_quote("#define IKEEXT_CERT_AUTH_ALLOW_HTTP_CERT_LOOKUP      (0x10)")
cpp_quote("#define IKEEXT_CERT_AUTH_URL_CONTAINS_BUNDLE         (0x20)")
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#define IKEEXT_KERB_AUTH_DISABLE_INITIATOR_TOKEN_GENERATION (0x1)")
cpp_quote("#define IKEEXT_KERB_AUTH_DONT_ACCEPT_EXPLICIT_CREDENTIALS   (0x2)")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
cpp_quote("#define IKEEXT_KERB_AUTH_FORCE_PROXY_ON_INITIATOR           (0x4)")
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#define IKEEXT_RESERVED_AUTH_DISABLE_INITIATOR_TOKEN_GENERATION (0x1)")
cpp_quote("")

cpp_quote("#define IKEEXT_NTLM_V2_AUTH_DONT_ACCEPT_EXPLICIT_CREDENTIALS (0x1)")
cpp_quote("")

cpp_quote("#define IKEEXT_POLICY_FLAG_DISABLE_DIAGNOSTICS (0x00000001)")
cpp_quote("#define IKEEXT_POLICY_FLAG_NO_MACHINE_LUID_VERIFY (0x00000002)")
cpp_quote("#define IKEEXT_POLICY_FLAG_NO_IMPERSONATION_LUID_VERIFY (0x00000004)")
cpp_quote("#define IKEEXT_POLICY_FLAG_ENABLE_OPTIONAL_DH (0x00000008)")

cpp_quote("")

cpp_quote("#define IKEEXT_CERT_CREDENTIAL_FLAG_NAP_CERT (0x1)")
cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
cpp_quote("#define IKEEXT_PSK_FLAG_LOCAL_AUTH_ONLY  (0x1)")
cpp_quote("#define IKEEXT_PSK_FLAG_REMOTE_AUTH_ONLY (0x2)")
cpp_quote("")
cpp_quote("#define IKEEXT_EAP_FLAG_LOCAL_AUTH_ONLY   (0x1)")
cpp_quote("#define IKEEXT_EAP_FLAG_REMOTE_AUTH_ONLY  (0x2)")
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#ifndef __IPSEC_V4_UDP_ENCAPSULATION0_FWD_DECLARED")
cpp_quote("#define __IPSEC_V4_UDP_ENCAPSULATION0_FWD_DECLARED")
typedef struct IPSEC_V4_UDP_ENCAPSULATION0_ IPSEC_V4_UDP_ENCAPSULATION0;
cpp_quote("#endif")
cpp_quote("")

typedef UINT64 IKEEXT_COOKIE;

cpp_quote("")
typedef [v1_enum] enum IKEEXT_EM_SA_STATE_ {
  IKEEXT_EM_SA_STATE_NONE,
  IKEEXT_EM_SA_STATE_SENT_ATTS,
  IKEEXT_EM_SA_STATE_SSPI_SENT,
  IKEEXT_EM_SA_STATE_AUTH_COMPLETE,
  IKEEXT_EM_SA_STATE_FINAL,
  IKEEXT_EM_SA_STATE_COMPLETE,
  IKEEXT_EM_SA_STATE_MAX
} IKEEXT_EM_SA_STATE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_SA_ROLE_ {
  IKEEXT_SA_ROLE_INITIATOR,
  IKEEXT_SA_ROLE_RESPONDER,
  IKEEXT_SA_ROLE_MAX
} IKEEXT_SA_ROLE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_AUTHENTICATION_METHOD_TYPE_ {
  IKEEXT_PRESHARED_KEY,
  IKEEXT_CERTIFICATE,
  IKEEXT_KERBEROS,
  IKEEXT_ANONYMOUS,
  IKEEXT_SSL,
  IKEEXT_NTLM_V2,
  IKEEXT_IPV6_CGA,
  IKEEXT_CERTIFICATE_ECDSA_P256,
  IKEEXT_CERTIFICATE_ECDSA_P384,
  IKEEXT_SSL_ECDSA_P256,
  IKEEXT_SSL_ECDSA_P384,
  IKEEXT_EAP,
  IKEEXT_RESERVED,
  IKEEXT_AUTHENTICATION_METHOD_TYPE_MAX
} IKEEXT_AUTHENTICATION_METHOD_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_KEY_MODULE_TYPE_ {
  IKEEXT_KEY_MODULE_IKE,
  IKEEXT_KEY_MODULE_AUTHIP,
  IKEEXT_KEY_MODULE_IKEV2,
  IKEEXT_KEY_MODULE_MAX
} IKEEXT_KEY_MODULE_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_MM_SA_STATE_ {
  IKEEXT_MM_SA_STATE_NONE,
  IKEEXT_MM_SA_STATE_SA_SENT,
  IKEEXT_MM_SA_STATE_SSPI_SENT,
  IKEEXT_MM_SA_STATE_FINAL,
  IKEEXT_MM_SA_STATE_FINAL_SENT,
  IKEEXT_MM_SA_STATE_COMPLETE,
  IKEEXT_MM_SA_STATE_MAX
} IKEEXT_MM_SA_STATE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_QM_SA_STATE_ {
  IKEEXT_QM_SA_STATE_NONE,
  IKEEXT_QM_SA_STATE_INITIAL,
  IKEEXT_QM_SA_STATE_FINAL,
  IKEEXT_QM_SA_STATE_COMPLETE,
  IKEEXT_QM_SA_STATE_MAX
} IKEEXT_QM_SA_STATE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE_ {
  IKEEXT_IMPERSONATION_NONE,
  IKEEXT_IMPERSONATION_SOCKET_PRINCIPAL,
  IKEEXT_IMPERSONATION_MAX
} IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_CERT_CONFIG_TYPE_ {
  IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST,
  IKEEXT_CERT_CONFIG_ENTERPRISE_STORE,
  IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE,
  IKEEXT_CERT_CONFIG_UNSPECIFIED,
  IKEEXT_CERT_CONFIG_TYPE_MAX
} IKEEXT_CERT_CONFIG_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_CIPHER_TYPE_ {
  IKEEXT_CIPHER_DES,
  IKEEXT_CIPHER_3DES,
  IKEEXT_CIPHER_AES_128,
  IKEEXT_CIPHER_AES_192,
  IKEEXT_CIPHER_AES_256,
  IKEEXT_CIPHER_TYPE_MAX
} IKEEXT_CIPHER_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_INTEGRITY_TYPE_ {
  IKEEXT_INTEGRITY_MD5,
  IKEEXT_INTEGRITY_SHA1,
  IKEEXT_INTEGRITY_SHA_256,
  IKEEXT_INTEGRITY_SHA_384,
  IKEEXT_INTEGRITY_TYPE_MAX
} IKEEXT_INTEGRITY_TYPE;

cpp_quote("")

typedef [v1_enum] enum IKEEXT_DH_GROUP_ {
  IKEEXT_DH_GROUP_NONE,
  IKEEXT_DH_GROUP_1,
  IKEEXT_DH_GROUP_2,
  IKEEXT_DH_GROUP_14,
  IKEEXT_DH_GROUP_2048 = IKEEXT_DH_GROUP_14,
  IKEEXT_DH_ECP_256,
  IKEEXT_DH_ECP_384,
  IKEEXT_DH_GROUP_24,
  IKEEXT_DH_GROUP_MAX
} IKEEXT_DH_GROUP;

cpp_quote("")

typedef struct IKEEXT_CERT_ROOT_CONFIG0_ {
  FWP_BYTE_BLOB certData;
  UINT32 flags;
} IKEEXT_CERT_ROOT_CONFIG0;

cpp_quote("")

typedef struct IKEEXT_KERBEROS_AUTHENTICATION0__ {
  UINT32 flags;
} IKEEXT_KERBEROS_AUTHENTICATION0;

cpp_quote("")

typedef struct IKEEXT_NTLM_V2_AUTHENTICATION0__ {
  UINT32 flags;
} IKEEXT_NTLM_V2_AUTHENTICATION0;

cpp_quote("")

typedef struct IKEEXT_PRESHARED_KEY_AUTHENTICATION0__ {
  FWP_BYTE_BLOB presharedKey;
} IKEEXT_PRESHARED_KEY_AUTHENTICATION0;

cpp_quote("")

typedef struct IKEEXT_PRESHARED_KEY_AUTHENTICATION1__ {
  FWP_BYTE_BLOB presharedKey;
  UINT32 flags;
} IKEEXT_PRESHARED_KEY_AUTHENTICATION1;
cpp_quote("")

typedef struct IKEEXT_CERTIFICATE_AUTHENTICATION0_ {
  IKEEXT_CERT_CONFIG_TYPE inboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(inboundConfigType)]
  union {
    [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
    struct {
      UINT32 inboundRootArraySize;
      [size_is(inboundRootArraySize), unique]
      IKEEXT_CERT_ROOT_CONFIG0 *inboundRootArray;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *inboundEnterpriseStoreConfig;
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *inboundTrustedRootStoreConfig;
  };
  IKEEXT_CERT_CONFIG_TYPE outboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(outboundConfigType)]
  union {
    [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
    struct {
      UINT32 outboundRootArraySize;
      [size_is(outboundRootArraySize), unique]
      IKEEXT_CERT_ROOT_CONFIG0 *outboundRootArray;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *outboundEnterpriseStoreConfig;
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *outboundTrustedRootStoreConfig;
  };
  UINT32 flags;
} IKEEXT_CERTIFICATE_AUTHENTICATION0;
cpp_quote("")

cpp_quote("#if NTDDI_VERSION >= NTDDI_WIN7")
typedef struct IKEEXT_CERTIFICATE_AUTHENTICATION1_ {
  IKEEXT_CERT_CONFIG_TYPE inboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(inboundConfigType)]
  union {
      [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
      struct {
      UINT32 inboundRootArraySize;
      [size_is(inboundRootArraySize), unique]
      IKEEXT_CERT_ROOT_CONFIG0 *inboundRootArray;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *inboundEnterpriseStoreConfig;
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *inboundTrustedRootStoreConfig;
    [case(IKEEXT_CERT_CONFIG_UNSPECIFIED)];
  };
  IKEEXT_CERT_CONFIG_TYPE outboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(outboundConfigType)]
  union {
    [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
    struct {
      UINT32 outboundRootArraySize;
      [size_is(outboundRootArraySize), unique]
      IKEEXT_CERT_ROOT_CONFIG0 *outboundRootArray;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *outboundEnterpriseStoreConfig;
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    [unique] IKEEXT_CERT_ROOT_CONFIG0 *outboundTrustedRootStoreConfig;
    [case(IKEEXT_CERT_CONFIG_UNSPECIFIED)];
  };
  UINT32 flags;
  FWP_BYTE_BLOB localCertLocationUrl;
} IKEEXT_CERTIFICATE_AUTHENTICATION1;
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef enum IKEEXT_CERT_CRITERIA_NAME_TYPE_ {
   IKEEXT_CERT_CRITERIA_DNS,
   IKEEXT_CERT_CRITERIA_UPN,
   IKEEXT_CERT_CRITERIA_RFC822,
   IKEEXT_CERT_CRITERIA_CN,
   IKEEXT_CERT_CRITERIA_OU,
   IKEEXT_CERT_CRITERIA_O,
   IKEEXT_CERT_CRITERIA_DC,
   IKEEXT_CERT_CRITERIA_NAME_TYPE_MAX
} IKEEXT_CERT_CRITERIA_NAME_TYPE;

cpp_quote("")

typedef struct IKEEXT_CERT_EKUS0_ {
  ULONG numEku;
  [string, size_is(numEku), ref] LPSTR *eku;
} IKEEXT_CERT_EKUS0;

cpp_quote("")

typedef struct IKEEXT_CERT_NAME0_ {
  IKEEXT_CERT_CRITERIA_NAME_TYPE nameType;
  [string, ref] LPWSTR certName;
} IKEEXT_CERT_NAME0;

cpp_quote("")

typedef struct IKEEXT_CERTIFICATE_CRITERIA0_ {
   FWP_BYTE_BLOB certData;
   FWP_BYTE_BLOB certHash;
   [unique] IKEEXT_CERT_EKUS0 *eku;
   [unique] IKEEXT_CERT_NAME0 *name;
   UINT32 flags;
} IKEEXT_CERTIFICATE_CRITERIA0;

cpp_quote("")

typedef struct IKEEXT_CERTIFICATE_AUTHENTICATION2_ {
  IKEEXT_CERT_CONFIG_TYPE inboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(inboundConfigType)]
  union {
    [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
    struct {
      UINT32 inboundRootArraySize;
      [size_is(inboundRootArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *inboundRootCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]        
    struct {
      UINT32 inboundEnterpriseStoreArraySize;
      [size_is(inboundEnterpriseStoreArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *inboundEnterpriseStoreCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    struct {
      UINT32 inboundRootStoreArraySize;
      [size_is(inboundRootStoreArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *inboundTrustedRootStoreCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_UNSPECIFIED)];
  };
  IKEEXT_CERT_CONFIG_TYPE outboundConfigType;
  [switch_type(IKEEXT_CERT_CONFIG_TYPE), switch_is(outboundConfigType)]
  union {
    [case(IKEEXT_CERT_CONFIG_EXPLICIT_TRUST_LIST)]
    struct {
      UINT32 outboundRootArraySize;
      [size_is(outboundRootArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *outboundRootCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_ENTERPRISE_STORE)]
    struct {
      UINT32 outboundEnterpriseStoreArraySize;
      [size_is(outboundEnterpriseStoreArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *outboundEnterpriseStoreCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_TRUSTED_ROOT_STORE)]
    struct {
      UINT32 outboundRootStoreArraySize;
      [size_is(outboundRootStoreArraySize), unique]
      IKEEXT_CERTIFICATE_CRITERIA0 *outboundTrustedRootStoreCriteria;
    };
    [case(IKEEXT_CERT_CONFIG_UNSPECIFIED)];
  };
  UINT32 flags;
  FWP_BYTE_BLOB localCertLocationUrl;
} IKEEXT_CERTIFICATE_AUTHENTICATION2;
cpp_quote("#endif")
cpp_quote("")

typedef struct IKEEXT_IPV6_CGA_AUTHENTICATION0_ {
  [string, ref] wchar_t *keyContainerName;
  [string, unique] wchar_t *cspName;
  UINT32 cspType;
  FWP_BYTE_ARRAY16 cgaModifier;
  BYTE cgaCollisionCount;
} IKEEXT_IPV6_CGA_AUTHENTICATION0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef struct IKEEXT_KERBEROS_AUTHENTICATION1__ {
  UINT32 flags;
  [string, unique] wchar_t *proxyServer;
} IKEEXT_KERBEROS_AUTHENTICATION1;
cpp_quote("#endif")
cpp_quote("")

typedef struct IKEEXT_RESERVED_AUTHENTICATION0__ {
  UINT32 flags;
} IKEEXT_RESERVED_AUTHENTICATION0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_EAP_AUTHENTICATION0__ {
  UINT32 flags;
} IKEEXT_EAP_AUTHENTICATION0;
cpp_quote("#endif")
cpp_quote("")

typedef struct IKEEXT_AUTHENTICATION_METHOD0_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
  switch_is(authenticationMethodType)]
  union {
    [case(IKEEXT_PRESHARED_KEY)]
    IKEEXT_PRESHARED_KEY_AUTHENTICATION0 presharedKeyAuthentication;
    [case(IKEEXT_CERTIFICATE,
     IKEEXT_CERTIFICATE_ECDSA_P256,
     IKEEXT_CERTIFICATE_ECDSA_P384)]
    IKEEXT_CERTIFICATE_AUTHENTICATION0 certificateAuthentication;
    [case(IKEEXT_KERBEROS)]
    IKEEXT_KERBEROS_AUTHENTICATION0 kerberosAuthentication;
    [case(IKEEXT_NTLM_V2)]
    IKEEXT_NTLM_V2_AUTHENTICATION0 ntlmV2Authentication;
    [case(IKEEXT_ANONYMOUS)];
    [case(IKEEXT_SSL,
     IKEEXT_SSL_ECDSA_P256,
     IKEEXT_SSL_ECDSA_P384)]
    IKEEXT_CERTIFICATE_AUTHENTICATION0 sslAuthentication;
    [case(IKEEXT_IPV6_CGA)]
    IKEEXT_IPV6_CGA_AUTHENTICATION0 cgaAuthentication;
  };
} IKEEXT_AUTHENTICATION_METHOD0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_AUTHENTICATION_METHOD1_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
  switch_is(authenticationMethodType)] union {
    [case(IKEEXT_PRESHARED_KEY)]
       IKEEXT_PRESHARED_KEY_AUTHENTICATION1 presharedKeyAuthentication;
    [case(IKEEXT_CERTIFICATE,
          IKEEXT_CERTIFICATE_ECDSA_P256,
          IKEEXT_CERTIFICATE_ECDSA_P384)]
       IKEEXT_CERTIFICATE_AUTHENTICATION1 certificateAuthentication;
    [case(IKEEXT_KERBEROS)]
       IKEEXT_KERBEROS_AUTHENTICATION0 kerberosAuthentication;
    [case(IKEEXT_NTLM_V2)]
       IKEEXT_NTLM_V2_AUTHENTICATION0 ntlmV2Authentication;
    [case(IKEEXT_ANONYMOUS)];
    [case(IKEEXT_SSL,
          IKEEXT_SSL_ECDSA_P256,
          IKEEXT_SSL_ECDSA_P384)]
       IKEEXT_CERTIFICATE_AUTHENTICATION1 sslAuthentication;
    [case(IKEEXT_IPV6_CGA)]
       IKEEXT_IPV6_CGA_AUTHENTICATION0 cgaAuthentication;
    [case(IKEEXT_EAP)]
       IKEEXT_EAP_AUTHENTICATION0 eapAuthentication;
  };
} IKEEXT_AUTHENTICATION_METHOD1;
cpp_quote("#endif")
cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef struct IKEEXT_AUTHENTICATION_METHOD2_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
  switch_is(authenticationMethodType)] union {
    [case(IKEEXT_PRESHARED_KEY)]
    IKEEXT_PRESHARED_KEY_AUTHENTICATION1 presharedKeyAuthentication;
    [case(IKEEXT_CERTIFICATE,
     IKEEXT_CERTIFICATE_ECDSA_P256,
     IKEEXT_CERTIFICATE_ECDSA_P384)]
    IKEEXT_CERTIFICATE_AUTHENTICATION2 certificateAuthentication;
    [case(IKEEXT_KERBEROS)]
    IKEEXT_KERBEROS_AUTHENTICATION1 kerberosAuthentication;
    [case(IKEEXT_RESERVED)]
    IKEEXT_RESERVED_AUTHENTICATION0 reservedAuthentication;
    [case(IKEEXT_NTLM_V2)]
    IKEEXT_NTLM_V2_AUTHENTICATION0 ntlmV2Authentication;
    [case(IKEEXT_ANONYMOUS)];
    [case(IKEEXT_SSL,
     IKEEXT_SSL_ECDSA_P256,
     IKEEXT_SSL_ECDSA_P384)]
    IKEEXT_CERTIFICATE_AUTHENTICATION2 sslAuthentication;
    [case(IKEEXT_IPV6_CGA)]
    IKEEXT_IPV6_CGA_AUTHENTICATION0 cgaAuthentication;
    [case(IKEEXT_EAP)]
    IKEEXT_EAP_AUTHENTICATION0 eapAuthentication;
  };
} IKEEXT_AUTHENTICATION_METHOD2;
cpp_quote("#endif")
cpp_quote("")

typedef struct IKEEXT_CIPHER_ALGORITHM0_ {
  IKEEXT_CIPHER_TYPE algoIdentifier;
  UINT32 keyLen;
  UINT32 rounds;
} IKEEXT_CIPHER_ALGORITHM0;

cpp_quote("")

typedef struct IKEEXT_INTEGRITY_ALGORITHM0_ {
  IKEEXT_INTEGRITY_TYPE algoIdentifier;
} IKEEXT_INTEGRITY_ALGORITHM0;

cpp_quote("")

typedef struct IKEEXT_PROPOSAL0_ {
  IKEEXT_CIPHER_ALGORITHM0 cipherAlgorithm;
  IKEEXT_INTEGRITY_ALGORITHM0 integrityAlgorithm;
  UINT32 maxLifetimeSeconds;
  IKEEXT_DH_GROUP dhGroup;
  UINT32 quickModeLimit;
} IKEEXT_PROPOSAL0;

cpp_quote("")

typedef struct IKEEXT_POLICY0_ {
  UINT32 softExpirationTime;
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD0 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
  UINT32 numIkeProposals;
  [size_is(numIkeProposals), ref] IKEEXT_PROPOSAL0 *ikeProposals;
  UINT32 flags;
  UINT32 maxDynamicFilters;
} IKEEXT_POLICY0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_POLICY1_ {
  UINT32 softExpirationTime;
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD1 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
  UINT32 numIkeProposals;
  [size_is(numIkeProposals), ref] IKEEXT_PROPOSAL0 *ikeProposals;
  UINT32 flags;
  UINT32 maxDynamicFilters;
  UINT32 retransmitDurationSecs;
} IKEEXT_POLICY1;
cpp_quote("#endif")

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef struct IKEEXT_POLICY2_ {
  UINT32 softExpirationTime;
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD2 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
  UINT32 numIkeProposals;
  [size_is(numIkeProposals), ref] IKEEXT_PROPOSAL0 *ikeProposals;
  UINT32 flags;
  UINT32 maxDynamicFilters;
  UINT32 retransmitDurationSecs;
} IKEEXT_POLICY2;
cpp_quote("#endif")
cpp_quote("")

typedef struct IKEEXT_EM_POLICY0_ {
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD0 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
} IKEEXT_EM_POLICY0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_EM_POLICY1_ {
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD1 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
} IKEEXT_EM_POLICY1;
cpp_quote("#endif")

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef struct IKEEXT_EM_POLICY2_ {
  UINT32 numAuthenticationMethods;
  [size_is(numAuthenticationMethods), ref]
  IKEEXT_AUTHENTICATION_METHOD2 *authenticationMethods;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE initiatorImpersonationType;
} IKEEXT_EM_POLICY2;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS0_ {
  UINT32 currentActiveMainModes;
  UINT32 totalMainModesStarted;
  UINT32 totalSuccessfulMainModes;
  UINT32 totalFailedMainModes;
  UINT32 totalResponderMainModes;
  UINT32 currentNewResponderMainModes;
  UINT32 currentActiveQuickModes;
  UINT32 totalQuickModesStarted;
  UINT32 totalSuccessfulQuickModes;
  UINT32 totalFailedQuickModes;
  UINT32 totalAcquires;
  UINT32 totalReinitAcquires;
  UINT32 currentActiveExtendedModes;
  UINT32 totalExtendedModesStarted;
  UINT32 totalSuccessfulExtendedModes;
  UINT32 totalFailedExtendedModes;
  UINT32 totalImpersonationExtendedModes;
  UINT32 totalImpersonationMainModes;
} IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS1_ {
  UINT32 currentActiveMainModes;
  UINT32 totalMainModesStarted;
  UINT32 totalSuccessfulMainModes;
  UINT32 totalFailedMainModes;
  UINT32 totalResponderMainModes;
  UINT32 currentNewResponderMainModes;
  UINT32 currentActiveQuickModes;
  UINT32 totalQuickModesStarted;
  UINT32 totalSuccessfulQuickModes;
  UINT32 totalFailedQuickModes;
  UINT32 totalAcquires;
  UINT32 totalReinitAcquires;
  UINT32 currentActiveExtendedModes;
  UINT32 totalExtendedModesStarted;
  UINT32 totalSuccessfulExtendedModes;
  UINT32 totalFailedExtendedModes;
  UINT32 totalImpersonationExtendedModes;
  UINT32 totalImpersonationMainModes;
} IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS1;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_KEYMODULE_STATISTICS0_ {
  IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS0 v4Statistics;
  IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS0 v6Statistics;
  UINT32 errorFrequencyTable[IKEEXT_ERROR_CODE_COUNT];
  UINT32 mainModeNegotiationTime;
  UINT32 quickModeNegotiationTime;
  UINT32 extendedModeNegotiationTime;
} IKEEXT_KEYMODULE_STATISTICS0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_KEYMODULE_STATISTICS1_ {
  IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS1 v4Statistics;
  IKEEXT_IP_VERSION_SPECIFIC_KEYMODULE_STATISTICS1 v6Statistics;
  UINT32 errorFrequencyTable[IKEEXT_ERROR_CODE_COUNT];
  UINT32 mainModeNegotiationTime;
  UINT32 quickModeNegotiationTime;
  UINT32 extendedModeNegotiationTime;
} IKEEXT_KEYMODULE_STATISTICS1;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS0_ {
  UINT32 totalSocketReceiveFailures;
  UINT32 totalSocketSendFailures;
} IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS0;

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS1_ {
  UINT32 totalSocketReceiveFailures;
  UINT32 totalSocketSendFailures;
} IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS1;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_COMMON_STATISTICS0_ {
  IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS0 v4Statistics;
  IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS0 v6Statistics;
  UINT32 totalPacketsReceived;
  UINT32 totalInvalidPacketsReceived;
  UINT32 currentQueuedWorkitems;
} IKEEXT_COMMON_STATISTICS0;

cpp_quote("")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_COMMON_STATISTICS1_ {
  IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS1 v4Statistics;
  IKEEXT_IP_VERSION_SPECIFIC_COMMON_STATISTICS1 v6Statistics;
  UINT32 totalPacketsReceived;
  UINT32 totalInvalidPacketsReceived;
  UINT32 currentQueuedWorkitems;
} IKEEXT_COMMON_STATISTICS1;
cpp_quote("#endif")

cpp_quote("")
typedef struct IKEEXT_STATISTICS0_ {
  IKEEXT_KEYMODULE_STATISTICS0 ikeStatistics;
  IKEEXT_KEYMODULE_STATISTICS0 authipStatistics;
  IKEEXT_COMMON_STATISTICS0 commonStatistics;
} IKEEXT_STATISTICS0;

cpp_quote("")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_STATISTICS1_ {
  IKEEXT_KEYMODULE_STATISTICS1 ikeStatistics;
  IKEEXT_KEYMODULE_STATISTICS1 authipStatistics;
  IKEEXT_KEYMODULE_STATISTICS1 ikeV2Statistics;
  IKEEXT_COMMON_STATISTICS1 commonStatistics;
} IKEEXT_STATISTICS1;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_TRAFFIC0_ {
  FWP_IP_VERSION ipVersion;
  [switch_type(FWP_IP_VERSION), switch_is(ipVersion)] union {
     [case(FWP_IP_VERSION_V4)]
        UINT32 localV4Address;
     [case(FWP_IP_VERSION_V6)]
        UINT8 localV6Address[16];
  };
  [switch_type(FWP_IP_VERSION), switch_is(ipVersion)] union {
     [case(FWP_IP_VERSION_V4)]
        UINT32 remoteV4Address;
     [case(FWP_IP_VERSION_V6)]
        UINT8 remoteV6Address[16];
  };
  UINT64 authIpFilterId;
} IKEEXT_TRAFFIC0;

cpp_quote("")

typedef struct IKEEXT_COOKIE_PAIR0_ {
  IKEEXT_COOKIE initiator;
  IKEEXT_COOKIE responder;
} IKEEXT_COOKIE_PAIR0;

cpp_quote("")

typedef struct IKEEXT_CERTIFICATE_CREDENTIAL0_ {
  FWP_BYTE_BLOB subjectName;
  FWP_BYTE_BLOB certHash;
  UINT32 flags;
} IKEEXT_CERTIFICATE_CREDENTIAL0;

cpp_quote("")

typedef struct IKEEXT_NAME_CREDENTIAL0_ {
  [string, ref] wchar_t *principalName;
} IKEEXT_NAME_CREDENTIAL0;

typedef struct IKEEXT_CREDENTIAL0_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE impersonationType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
   switch_is(authenticationMethodType)] union {
     [case(IKEEXT_PRESHARED_KEY)]
        [unique] IKEEXT_PRESHARED_KEY_AUTHENTICATION0 *presharedKey;
     [case(IKEEXT_CERTIFICATE,
           IKEEXT_CERTIFICATE_ECDSA_P256,
           IKEEXT_CERTIFICATE_ECDSA_P384,
           IKEEXT_SSL,
           IKEEXT_SSL_ECDSA_P256,
           IKEEXT_SSL_ECDSA_P384,
           IKEEXT_IPV6_CGA
           )]
        [unique] IKEEXT_CERTIFICATE_CREDENTIAL0 *certificate;
     [case(IKEEXT_KERBEROS,
           IKEEXT_EAP,
           IKEEXT_NTLM_V2)]
        [unique] IKEEXT_NAME_CREDENTIAL0 *name;
     [case(IKEEXT_ANONYMOUS)];
  };
} IKEEXT_CREDENTIAL0;

cpp_quote("")

typedef struct IKEEXT_CREDENTIAL_PAIR0_ {
  IKEEXT_CREDENTIAL0 localCredentials;
  IKEEXT_CREDENTIAL0 peerCredentials;
} IKEEXT_CREDENTIAL_PAIR0;

cpp_quote("")

typedef struct IKEEXT_CREDENTIALS0_ {
  UINT32 numCredentials;
  [size_is(numCredentials), ref] IKEEXT_CREDENTIAL_PAIR0 *credentials;
} IKEEXT_CREDENTIALS0;

cpp_quote("")

typedef struct IKEEXT_SA_DETAILS0_ {
  UINT64 saId;
  IKEEXT_KEY_MODULE_TYPE keyModuleType;
  FWP_IP_VERSION ipVersion;
  [switch_type(FWP_IP_VERSION), switch_is(ipVersion)] union {
     [case(FWP_IP_VERSION_V4)]
        [unique] IPSEC_V4_UDP_ENCAPSULATION0 *v4UdpEncapsulation;
     [case(FWP_IP_VERSION_V6)];
  };
  IKEEXT_TRAFFIC0 ikeTraffic;
  IKEEXT_PROPOSAL0 ikeProposal;
  IKEEXT_COOKIE_PAIR0 cookiePair;
  IKEEXT_CREDENTIALS0 ikeCredentials;
  GUID ikePolicyKey;
  UINT64 virtualIfTunnelId;
} IKEEXT_SA_DETAILS0;

cpp_quote("")
cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN7)")
typedef struct IKEEXT_CERTIFICATE_CREDENTIAL1_ {
  FWP_BYTE_BLOB subjectName;
  FWP_BYTE_BLOB certHash;
  UINT32 flags;
  FWP_BYTE_BLOB certificate;
} IKEEXT_CERTIFICATE_CREDENTIAL1;

cpp_quote("")

typedef struct IKEEXT_CREDENTIAL1_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE impersonationType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
  switch_is(authenticationMethodType)] union {
    [case(IKEEXT_PRESHARED_KEY)]
       [unique] IKEEXT_PRESHARED_KEY_AUTHENTICATION1 *presharedKey;
    [case(IKEEXT_CERTIFICATE,
          IKEEXT_CERTIFICATE_ECDSA_P256,
          IKEEXT_CERTIFICATE_ECDSA_P384,
          IKEEXT_SSL,
          IKEEXT_SSL_ECDSA_P256,
          IKEEXT_SSL_ECDSA_P384,
          IKEEXT_IPV6_CGA
          )]
       [unique] IKEEXT_CERTIFICATE_CREDENTIAL1 *certificate;
    [case(IKEEXT_KERBEROS,
          IKEEXT_EAP,
          IKEEXT_NTLM_V2)]
       [unique] IKEEXT_NAME_CREDENTIAL0 *name;
    [case(IKEEXT_ANONYMOUS)];
  };
} IKEEXT_CREDENTIAL1;

cpp_quote("")

typedef struct IKEEXT_CREDENTIAL_PAIR1_ {
  IKEEXT_CREDENTIAL1 localCredentials;
  IKEEXT_CREDENTIAL1 peerCredentials;
} IKEEXT_CREDENTIAL_PAIR1;

cpp_quote("")

typedef struct IKEEXT_CREDENTIALS1_ {
  UINT32 numCredentials;
  [size_is(numCredentials), ref] IKEEXT_CREDENTIAL_PAIR1 *credentials;
} IKEEXT_CREDENTIALS1;

cpp_quote("")

typedef struct IKEEXT_SA_DETAILS1_ {
  UINT64 saId;
  IKEEXT_KEY_MODULE_TYPE keyModuleType;
  FWP_IP_VERSION ipVersion;
  [switch_type(FWP_IP_VERSION), switch_is(ipVersion)] union {
    [case(FWP_IP_VERSION_V4)]
       [unique] IPSEC_V4_UDP_ENCAPSULATION0 *v4UdpEncapsulation;
    [case(FWP_IP_VERSION_V6)];
  };
  IKEEXT_TRAFFIC0 ikeTraffic;
  IKEEXT_PROPOSAL0 ikeProposal;
  IKEEXT_COOKIE_PAIR0 cookiePair;
  IKEEXT_CREDENTIALS1 ikeCredentials;
  GUID ikePolicyKey;
  UINT64 virtualIfTunnelId;
  FWP_BYTE_BLOB correlationKey;
} IKEEXT_SA_DETAILS1;
cpp_quote("#endif")

cpp_quote("")

cpp_quote("#if (NTDDI_VERSION >= NTDDI_WIN8)")
typedef struct IKEEXT_CREDENTIAL2_ {
  IKEEXT_AUTHENTICATION_METHOD_TYPE authenticationMethodType;
  IKEEXT_AUTHENTICATION_IMPERSONATION_TYPE impersonationType;
  [switch_type(IKEEXT_AUTHENTICATION_METHOD_TYPE),
  switch_is(authenticationMethodType)] union
  {
    [case(IKEEXT_PRESHARED_KEY)]
       [unique] IKEEXT_PRESHARED_KEY_AUTHENTICATION1 *presharedKey;
    [case(IKEEXT_CERTIFICATE,
          IKEEXT_CERTIFICATE_ECDSA_P256,
          IKEEXT_CERTIFICATE_ECDSA_P384,
          IKEEXT_SSL,
          IKEEXT_SSL_ECDSA_P256,
          IKEEXT_SSL_ECDSA_P384,
          IKEEXT_IPV6_CGA
          )]
       [unique] IKEEXT_CERTIFICATE_CREDENTIAL1 *certificate;
    [case(IKEEXT_KERBEROS,
          IKEEXT_EAP,
          IKEEXT_NTLM_V2,
          IKEEXT_RESERVED)]
       [unique] IKEEXT_NAME_CREDENTIAL0 *name;
    [case(IKEEXT_ANONYMOUS)];
  };
} IKEEXT_CREDENTIAL2;

cpp_quote("")

typedef struct IKEEXT_CREDENTIAL_PAIR2_ {
  IKEEXT_CREDENTIAL2 localCredentials;
  IKEEXT_CREDENTIAL2 peerCredentials;
} IKEEXT_CREDENTIAL_PAIR2;

cpp_quote("")

typedef struct IKEEXT_CREDENTIALS2_ {
  UINT32 numCredentials;
  [size_is(numCredentials), ref] IKEEXT_CREDENTIAL_PAIR2 *credentials;
} IKEEXT_CREDENTIALS2;

cpp_quote("")

typedef struct IKEEXT_SA_DETAILS2_ {
  UINT64 saId;
  IKEEXT_KEY_MODULE_TYPE keyModuleType;
  FWP_IP_VERSION ipVersion;
  [switch_type(FWP_IP_VERSION), switch_is(ipVersion)] union {
    [case(FWP_IP_VERSION_V4)]
       [unique] IPSEC_V4_UDP_ENCAPSULATION0 *v4UdpEncapsulation;
    [case(FWP_IP_VERSION_V6)];
  };
  IKEEXT_TRAFFIC0 ikeTraffic;
  IKEEXT_PROPOSAL0 ikeProposal;
  IKEEXT_COOKIE_PAIR0 cookiePair;
  IKEEXT_CREDENTIALS2 ikeCredentials;
  GUID ikePolicyKey;
  UINT64 virtualIfTunnelId;
  FWP_BYTE_BLOB correlationKey;
} IKEEXT_SA_DETAILS2;
cpp_quote("#endif")

cpp_quote("")

typedef struct IKEEXT_SA_ENUM_TEMPLATE0_ {
  FWP_CONDITION_VALUE0 localSubNet;
  FWP_CONDITION_VALUE0 remoteSubNet;
  FWP_BYTE_BLOB localMainModeCertHash;
} IKEEXT_SA_ENUM_TEMPLATE0;

cpp_quote("")
cpp_quote("#endif /* WINAPI_PARTITION_DESKTOP.  */")