Часть 2, Архитектура.
Введение.
Рассмотрим типичный жизненный цикл обмена информацией по протоколу TCP.
1. Приложение (клиент) вызывает функцию connect, указывая адрес и порт пункта
назначения, а также семейство и тип протокола. Или же (сервер) оно вызывает accept в
ожидании подключений.
2. Через некоторое время соединение установлено. Клиенту возвращается управление из
функции connect (ну или приходит соответствующий сигнал, как в случае с моделью
select или асинхронным I/O — это уже за рамками темы), серверу возвращается
новый сокет, связанный с клиентом.
3. Приложения обмениваются данными посредством функций send и recv.
4. Приложения закрывают свои концы соединений функцией shutdown.
Когда оба конца закрыты, связь завершается, соединение считается разомкнутым.
Представим, что мы пишем фильтр TCP-трафика, и нас на каждом шаге этой
последовательности интересуют определенные данные:
1. Адрес и порт пункта назначения, ID процесса, который выполнил connect/accept.
Имя и вообще контекст безопасности пользователя, которому принадлежит процесс.
2. Статус операции connect (успех или ошибка).
3. Буферы, передаваемые через send и recv.
Предположим, мы хотим блокировать нежелательные соединения (по набору запрещенных
IP-адресов и портов, а также по процессам или пользователям). Мы также хотим получать
уведомление о закрытии соединения (п.4), чтобы освободить все связанные с ним данные.
WFP для решения этой задачи предлагает несколько абстракций:
Layers — уровни фильтрации. Каждым уровнем обслуживается определенный этап обработки
соединения или передачи данных. Например, установка соединения обрабатывается на
уровне ALE (будет рассмотрен ниже), а работа с буферами send/recv — на уровне Stream.
У каждого уровня своя специфика и свой набор свойств, с которыми можно работать.
Часто ту информацию, что можно достать на одном уровне, уже нельзя увидеть на других.
Аналогично, не все функции, которые работают на одних уровнях, работают на других.
Sublayers — подуровни. Нужны для организации более гибкой стратегии фильтрации.
Например, можно зарегистрировать проверки на разных Sublayers и они будут выполняться
по очереди.
Filters — фильтры. Задают разные условия, при которых должна (или не должна) выполняться
фильтрация. Например, можно фильтровать только трафик, идущий на порт 80, а остальной
игнорировать. Фильтры определяют не только условия, но и действия, т.е. что делать с трафиком,
когда условие срабатывает. Основные операции: разрешить, заблокировать, задержать, либо
вызвать соответствующий Callout. Про Callout-ы будет написано ниже.
Conditions — условия, заданные в фильтре. В фильтре может быть несколько условий.
Shims — исполнительные объекты, расположенные во всех ключевых точках сетевого стека.
Если Filters и Conditions только задают правила, что делать с трафиком, то Shims отвечают за
само выполнение этих правил, т.е. блокировка, задержка трафика, вызов Callout-а и так далее.
Callout — блок функций, которые обрабатывают трафик и решают, что конкретно с ним делать.
Callout Driver — драйвер, реализующий один или несколько Callout-ов.
Provider — поставщик. Объединяет логически связанные Filters, Sublayers и Callouts,
принадлежащие одной программе, одной задаче/политике, или объединенные какими-то
другими общими признаками.
Filter Engine (Engine) — функциональное ядро WFP, которое управляет фильтрами, Shim-ами,
Callout-ами и остальными объектами технологии.
Base Filter Engine (BFE) — служба, отвечающая за координацию компонентов WFP, за
регистрацию новых фильтров, за хранение конфигурации, настройки безопасности и т.д.
Ссылки по теме:
WFP Architecture
http://msdn.microsoft.com/en-u… 85%29.aspx
Object Model
http://msdn.microsoft.com/en-u… 85%29.aspx
Как это работает.
Когда в сетевом стеке происходит какое-то событие, например установка или закрытие
соединения, приход дейтаграммы, получение буфера с данными и т.п., Filter Engine с
помощью Filters определяет, нужно ли как-то обрабатывать это событие. В терминах WFP
данный процесс называется классификацией (classify). Если хотя бы один Condition
срабатывает, вызывается Shim, который, в зависимости от того, что задано в фильтре,
выполняет нужное действие. В частности, Shim может вызвать ваш зарегистрированный
Callout, точнее, одну из его функций (их всего три).
Все остальное выполняет Callout, в соответствии с логикой фильтрации трафика.
Если, к примеру, Callout работает на уровне ALE, то в функцию ему будут переданы
адрес и порт пункта назначения и источника, тип протокола, ID приложения, полный
путь к exe и другая полезная информация. Если на уровне Stream, там будут другие
данные — направление трафика (входящий/исходящий), флаги и т.д. Далее Callout
может поступать с данными на свое усмотрение: блокировка, игнор, редирект, анализ,
задержка трафика и многое другое. Все ограничено лишь фантазией разработчика.
Выше была описана типичная последовательность операций при работе с TCP.
Давайте посмотрим, как она будет фильтроваться WFP.
1. Установка соединения (connect).
Здесь будут срабатывать фильтры на уровне FWPS_LAYER_ALE_AUTH_CONNECT_V4.
Здесь же можно заблокировать соединение.
2. Соединение установлено.
Сработают фильтры на уровне FWPS_LAYER_ALE_FLOW_ESTABLISHED_V4.
Добавлю, что на этом уровне блокировать коннект не рекомендуется, он создан
только для того, чтобы Callout получил уведомление о том, успешно или нет
создано соединение. Здесь же можно установить связь между коннектом и
потоком данных.
3. Передача данных.
Будут срабатывать фильтры на уровне FWPS_LAYER_STREAM_V4, причем как
для send (outgoing data), так и для recv (incoming data).
4. Закрытие соединения.
Если с потоком данных был ассоциирован контекст, будет вызвана одна из
функций Callout-а. Также на Windows 7 есть специальные уровни для
очистки ресурсов — FWPS_LAYER_ALE_RESOURCE_RELEASE_V4.
Еще определения.
Flow (поток данных). Каждое соединение — это отдельный двунаправленный поток данных.
Если, к примеру, программа создает два коннекта на один и тот же адрес, вы будете в
драйвере видеть два разных потока данных, каждый со своим состоянием.
Flow Context (контекст потока). 64-битное число, ассоциированное с определенным
потоком данных. Нужно, чтобы отличать потоки друг от друга.
Fixed Values. Фиксированный набор аргументов, приходящий в Callout.
Описан здесь:
Data Field Identifiers
http://msdn.microsoft.com/en-u… 85%29.aspx
Для каждого Layer-а свой набор аргументов.
Например, на уровне FWPS_LAYER_ALE_CONNECT_REDIRECT_V4 (установка соединения) через
Fixed Values можно получить имя пользователя, а на уровне FWPS_LAYER_STREAM_V4
его уже нет.
Meta Values. Аналогично Fixed Values.
Информация здесь:
Metadata Fields at Each Filtering Layer
http://msdn.microsoft.com/en-u… 85%29.aspx
Итак, Callout, заглядывая в Fixed Values и Meta Values, решает, что делать с
данным событием/трафиком и предпринимает определенные действия, после чего весь
цикл повторяется заново. Доступ к буферам с данными осуществляется через
структуру NET_BUFFER (будет описана в следующих частях).
13
From Wikipedia, the free encyclopedia
Windows Filtering Platform (WFP) is a set of system services in Windows Vista and later that allows Windows software to process and filter network traffic. Microsoft intended WFP for use by firewalls, antimalware software, and parental controls apps. Additionally, WFP is used to implement NAT and to store IPSec policy configuration.
WFP relies on Windows Vista’s Next Generation TCP/IP stack. It provides features such as integrated communication and per-application processing logic. Since Windows 8 and Windows Server 2012, WFP allows filtering at the second layer of TCP/IP suite.
Components[edit]
The filtering platform includes the following components:
- Shims, which expose the internal structure of a packet as properties. Different shims exist for protocols at different layers. WFP comes with a set of shims; users can register shims for other protocols using the API. The in-built set of shims includes:
- Application Layer Enforcement (ALE) shim
- Transport Layer Module (TLM) shim
- Network Layer Module (NLM) shim
- RPC Runtime shim
- Internet Control Message Protocol (ICMP) shim
- Stream shim
- Filtering engine, which spans both kernel-mode and user-mode, providing basic filtering capabilities. It matches the data within a packet – as exposed by the shims – against filtering rules, and either blocks or permits the packet. A callout (see below) may implement any other action as required. The filters operate on a per-application basis. To mitigate conflicts between filters, they are given weights (priorities) and grouped into sublayers, which also have weights. Filters and callouts may be associated to providers which may be given a name and description and are essentially associated to a particular application or service.
- Base filtering engine, the module that manages the filtering engine. It accepts filtering rules and enforces the security model of the application. It also maintains statistics for the WFP and logs its state.
- Callout, a callback function exposed by a filtering driver. The filtering drivers provide filtering capabilities other than the default block/allow. Administrators specify a callout function during registration of a filter rule. When the filter matches, the system invokes the callout, which handles a specified action.
Diagnostics[edit]
Starting with Windows 7, the netsh command can diagnose of the internal state of WFP.
Hotfix[edit]
Microsoft released three out-of-band hotfixes for WPF in Windows Vista and Windows 7 to address issues that could cause a memory leak, loss of connectivity during a Remote Desktop Connection session, or a blue screen of death. Later, these hotfixes were rolled up into one package.[1]
References[edit]
- ^ «A Windows Filtering Platform (WFP) driver hotfix rollup package is available for Windows Vista, Windows Server 2008, Windows 7, and Windows Server 2008 R2». Windows support. Microsoft. 12 April 2010.
External links[edit]
- Windows Filtering Platform Architecture Overview
Device Fundamentals
>
Networking and Communications
Updated: May 13, 2004
On This Page
Introducing the Windows Filtering Platform
This paper provides information about the Windows Filtering Platform (WFP) for Microsoft� Windows� codenamed “Longhorn”.
WFP is a new architecture in Microsoft Windows codenamed “Longhorn” that allows unprecedented access to the TCP/IP packet processing path, wherein outgoing and incoming packets can be examined or changed before allowing them to be processed further. By tapping into the TCP/IP processing path, ISVs can create firewalls, anti-virus software, diagnostic software, and other types of applications and services.
WFP provides APIs so that third-party ISVs can participate in the filtering decisions that take place at several layers in the TCP/IP protocol stack and throughout the operating system. The platform also integrates and provides support for next-generation firewall features such as authenticated communication and dynamic firewall configuration based on applications� use of the Windows Sockets API (application-based policy).��
WFP is not a firewall. It is a set of system services and APIs to enable firewalls to be developed by Microsoft and third parties. The Longhorn Personal Firewall, the successor to the Internet Connection Firewall and Windows Firewall in Windows XP, will be built using WFP.
Why Should You Convert Your Applications and Services to WFP?
Microsoft Windows codenamed “Longhorn” includes a completely new architecture for the TCP/IP protocol stack, which now is an integrated implementation of both IPv4 and IPv6, known as a dual Internet layer stack.
This means that the methods of accessing the TCP/IP protocol stack for packet processing have changed significantly. These methods include the firewall hook, the filter hook, and other methods that involve custom solutions based on reverse engineering the current Windows TCP/IP protocol stack. For correct operation and to perform the equivalent function in Microsoft Windows codenamed “Longhorn”, you must change your application, service, or driver.
The specific methods for changing your existing code are described in the «Converting Applications to Use WFP» section of this paper. In most cases, it is a matter of mapping the current method of hooking into the TCP/IP packet processing path for the equivalent way for Microsoft Windows codenamed “Longhorn”. For reverse-engineered solutions, you must either substantially revise the way in which your code works or take advantage of WFP to provide the equivalent functionality.
Although it might be inconvenient for you to have to revise your component, the new TCP/IP protocol and WFP architecture offer new opportunities for value-added components and applications that rely on the TCP/IP packet processing path, opportunities that might not have existed prior to Microsoft Windows codenamed “Longhorn”.
The benefits of using WFP are the following:
• |
You have a fine level of access control to the TCP/IP packet processing path. |
• |
Because WFP already provides a filtering engine, you do not have to build the filtering logic. You can just tap into the WFP filtering engine and concentrate on the value added by your component. |
• |
In previous and current versions of Windows, existing hooks into TCP/IP packet processing path are poorly documented and supported. Microsoft is committed to supporting WFP in Microsoft Windows codenamed “Longhorn”. |
• |
When you use WFP instead of unconventional hooks into existing TC/IP stack, there is much less risk of breaking your component with a service pack release. |
• |
It is much easier to implement a firewall or packet filtering value-added solution because the filtering logic and hooks into the various layers of the TCP/IP protocol are already in place. |
• |
Depending on your component, it might be possible to move it out of kernel mode and into user mode, in which a component crash does not affect the entire Windows system. |
• |
Because all the applications and services use the same filtering engine, it is easier to determine if there are other applications or services performing the same function. |
Using WFP benefits you in the following situations:
• |
Your component needs to examine TCP/IP traffic at a specific layer of the new TCP/IP protocol stack. |
• |
Your component works with encrypted traffic. A significant portion of the network traffic for Microsoft Windows codenamed “Longhorn” will be encrypted. For example, all RPC traffic is encrypted by default in Microsoft Windows codenamed “Longhorn”. |
• |
You want to perform packet processing after decryption. |
• |
You want to do IPv6 packet filtering, and want to take advantage of a built-in IPv6 filtering engine, rather than building one yourself. |
WFP Architecture
Figure 1 shows the WFP architecture and where third-party applications, services, and drivers can plug in.
Figure 1. Architecture of the WFP for Third-Party Components
The WFP architecture consists of the following components:
• |
Longhorn API |
• |
Base Filtering Engine |
• |
Generic Filter Engine |
• |
Callout Modules |
There are two main ways that third-party ISVs can use the WFP architecture to build applications or service:
• |
For applications and services that only perform filtering functions, all that is required is a user mode application or service that uses the Longhorn APIs to set filters at the appropriate layers in the new TCP/IP stack. No kernel mode callout drivers are needed. |
• |
For applications and services that perform deep packet content inspection or modification, you must create a user-mode application or service and one or more callout drivers. The user mode application or service uses the Longhorn APIs to set filters at the appropriate layers in the new TCP/IP stack, subject to further inspection by a specified callout driver. When incoming or outgoing traffic matches these filters, the Generic Filtering Engine hands the packet to the callout driver, which performs inspection or modification functions before handing the packet back to the Generic Filter Engine. |
Converting Applications to Use WFP
The following table lists the ways in which existing third-party TCP/IP packet processing components written for the Windows XP or Windows Server 2003 TCP/IP protocol must be modified to work with the new WFP architecture.
Changes to Existing Stack Interfaces
Existing method | New method |
NDIS intermediate driver |
NDIS layer in the new TCP/IP protocol stack (see Figure 1) |
Firewall hook or filter hook |
IP Transport or Forwarding layers |
TDI |
Application Layer Enforcement (ALE) |
Windows Sockets Layered Service Provider (one that is providing firewall functionality) |
ALE or Stream layer |
References
Call to Action
• |
For firewall and filtering developers: Convert your existing filtering or packet inspection drivers to use the new callout APIs in Microsoft Windows codenamed “Longhorn”. |
• |
If you have questions about the new Windows Filtering Platform, send e-mail to wfp@microsoft.com. |
Resources
Windows Hardware and Driver Central
(includes Windows�Driver Development Kits [DDK], Windows�Hardware Compatibility Test [HCT] Kits, and Windows Logo Program requirements)
Search code, repositories, users, issues, pull requests…
Provide feedback
Saved searches
Use saved searches to filter your results more quickly
Sign up
Windows 7 / Networking
The Windows Filtering Platform (WFP) is an architectural feature of Windows Vista and
later versions that allows access to Transmission Control Protocol/Internet Protocol (TCP/
IP) packets as they are being processed by the TCP/IP networking stack. WFP is the engine
that implements packet-filtering logic, and it is accessible through a collection of public APIs
which provide hooks into the networking stack and the underlying filtering logic upon which
Windows Firewall is built. Independent Software Vendors (ISVs) can also use WFP to develop
third-party firewalls, network diagnostic software, antivirus software, and other types of
network applications. Using these APIs, a WFP-aware filtering application can access a packet
anywhere in the processing path to view or modify its contents. Third-party vendors and
network application developers should utilize the WFP APIs only for filtering applications or
security applications.
As shown in Figure below, the main features of the WFP are as follows:
- Base Filter Engine The Base Filter Engine (BFE) runs in user mode and receives filtering
requests made by Windows Firewall, third-party applications, and the legacy IPsec
policy service. The BFE then plumbs the filters created by these requests into the Kernel
Mode Generic Filter Engine. The BFE (Bfe.dll) runs within a generic SvcHost.exe process. - Generic Filter Engine The GFE receives the filters plumbed from the BFE and stores
them so that the different layers of the TCP/IP stack can access them. As the stack
processes a packet, each layer the packet encounters calls the GFE to determine whether
the packet should be passed or dropped. The GFE also calls the various callout modules
(defined next) to determine whether the packet should be passed or dropped. (Some
callouts may perform an identical function, especially if multiple third-party firewalls
are running concurrently.) The GFE (Wfp.lib) is part of the Kernel Mode Next Generation
TCP/IP Stack (NetioTcpip.sys) first introduced in Windows Vista. The GFE is actually the
Kernel Mode enforcement engine portion of the BFE and is not a separate feature. - Callout modules These features are used for performing deep inspection or data
modification of packets being processed by the pack. Callout modules store additional
filtering criteria that the GFE uses to determine whether a packet should be passed or dropped.
Note The BFE can support multiple clients simultaneously. This means that a third-party,
WFP-aware application can interact with and even override Windows Firewall with
Advanced Security if so designed.
The APIs of the BFE are all publicly documented so that ISVs can create applications that
hook into the advanced filtering capabilities of the Next Generation TCP/IP Stack in Windows
Vista and later versions. Some of the filtering features of the WFP are implemented using callouts,
but most filtering is performed using static filters created by the BFE as it interacts with
Windows Firewall. The Windows Firewall service monitors the system to make sure the filters
passed to BFE reflect the environment of the system at any given time. These public WFP APIs
are scriptable and expose the full configurability of Windows Firewall, but they have some
limitations, such as no support for IPsec integration.