/* * Copyright (C) 2013 Martin Willi * Copyright (C) 2013 revosec AG * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. See . * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ /** * @defgroup kernel_wfp_compat kernel_wfp_compat * @{ @ingroup kernel_wfp */ #ifndef KERNEL_WFP_COMPAT_H_ #define KERNEL_WFP_COMPAT_H_ #include #include #include /* MinGW defines CIPHERs incorrectly starting at 0 */ #define IPSEC_CIPHER_TYPE_DES 1 #define IPSEC_CIPHER_TYPE_3DES 2 #define IPSEC_CIPHER_TYPE_AES_128 3 #define IPSEC_CIPHER_TYPE_AES_192 4 #define IPSEC_CIPHER_TYPE_AES_256 5 #define IPSEC_CIPHER_TYPE_MAX 6 #include #include #undef interface /* MinGW defines TRANSFORMs incorrectly starting at 0 */ #define IPSEC_TRANSFORM_AH 1 #define IPSEC_TRANSFORM_ESP_AUTH 2 #define IPSEC_TRANSFORM_ESP_CIPHER 3 #define IPSEC_TRANSFORM_ESP_AUTH_AND_CIPHER 4 #define IPSEC_TRANSFORM_ESP_AUTH_FW 5 #define IPSEC_TRANSFORM_TYPE_MAX 6 /* missing in MinGW */ enum { FWPM_TUNNEL_FLAG_POINT_TO_POINT = (1<<0), FWPM_TUNNEL_FLAG_ENABLE_VIRTUAL_IF_TUNNELING = (1<<1), }; /* missing in MinGW */ enum { IPSEC_SA_DETAILS_UPDATE_TRAFFIC = (1<<0), IPSEC_SA_DETAILS_UPDATE_UDP_ENCAPSULATION = (1<<1), IPSEC_SA_BUNDLE_UPDATE_FLAGS = (1<<2), IPSEC_SA_BUNDLE_UPDATE_NAP_CONTEXT = (1<<3), IPSEC_SA_BUNDLE_UPDATE_KEY_MODULE_STATE = (1<<4), IPSEC_SA_BUNDLE_UPDATE_PEER_V4_PRIVATE_ADDRESS = (1<<5), IPSEC_SA_BUNDLE_UPDATE_MM_SA_ID = (1<<6), }; /* missing in MinGW */ enum { FWPM_NET_EVENT_FLAG_IP_PROTOCOL_SET = (1<<0), FWPM_NET_EVENT_FLAG_LOCAL_ADDR_SET = (1<<1), FWPM_NET_EVENT_FLAG_REMOTE_ADDR_SET = (1<<2), FWPM_NET_EVENT_FLAG_LOCAL_PORT_SET = (1<<3), FWPM_NET_EVENT_FLAG_REMOTE_PORT_SET = (1<<4), FWPM_NET_EVENT_FLAG_APP_ID_SET = (1<<5), FWPM_NET_EVENT_FLAG_USER_ID_SET = (1<<6), FWPM_NET_EVENT_FLAG_SCOPE_ID_SET = (1<<7), FWPM_NET_EVENT_FLAG_IP_VERSION_SET = (1<<8), FWPM_NET_EVENT_FLAG_REAUTH_REASON_SET = (1<<9), }; DWORD WINAPI FwpmIPsecTunnelAdd0(HANDLE, UINT32, const FWPM_PROVIDER_CONTEXT0*, const FWPM_PROVIDER_CONTEXT0*, UINT32, const FWPM_FILTER_CONDITION0*, PSECURITY_DESCRIPTOR); #endif /** KERNEL_WFP_COMPAT_H_ @}*/