Raf's laboratory Abstracts Feed Raffaele Rialdi personal website

I am Raf logo

Using Vista and Windows 7 Firewall from Visual C++

September 09, 2009
http://iamraf.net/Samples/Using-Vista-and-Windows-7-Firewall-from-Visual-C2b2b

In Vista the Firewall API changed a lot in comparison to the previous versions.

You can drive the Windows Firewall using a COM API, a layer over the Windows Filtering Platform. If you are thinking to develop directly the WFP, it's better to change your idea. WFP is a low level API to build Firewalls and not to be managed directly from traditional applications.

On the other side it's a long time that Visual C++ ship with the powerful #import directive that can save you a lot of time in COM client applications.

The starting point to use the firewall API in a Visual C++ project is the following statements in the stdafx.h:

#import "netfw.tlb" rename_namespace("fw")
#include <Netfw.h>

The import statement trigger the creation of two files:

  • netfw.tlh contains things like strong typed smartpointers for the types in the type library (_COM_SMARTPTR_TYPEDEF), enums and interface declarations
  • netfw.tli contains methods that wraps calls and throws exceptions in place of HRESULTs.

The rename_namespace directive is the way you can choose the C++ namespace name for all the code created in those two files, in our case "fw".

Using the COM API is now very simple. Let's see how to list the firewall rules:

typedef BOOL (*RuleCallback)(fw::INetFwRulePtr& Rule);

void ListRules(RuleCallback Callback)
{
  HRESULT hr;
  // Connect to the firewall
  fw::INetFwPolicy2Ptr Pol2;
  hr = Pol2.CreateInstance(__uuidof(fw::NetFwPolicy2));
  if(Pol2 == NULL)
      return;

  // Retrieve collection rules
  fw::INetFwRulesPtr Rules = Pol2->Rules;
  if(Rules == NULL)
      return;

  // enumerate the collection and call a callback function
  ULONG num;
  VARIANT obj;
  IEnumVARIANTPtr enumerator = Rules->Get_NewEnum();
  while(enumerator->Next(1, &obj, &num) == S_OK)
  {
      fw::INetFwRulePtr Rule = obj;
      if(!Callback(Rule))
          return;
  }
}

Adding, deleting, and working on service rules, is again very simple. The attached file contains a working Visual C++ 2008 sample with all those functions.



rated by 0 users



Share this page on Twitter


Privacy | Legal Copyright © Raffaele Rialdi 2009, Senior Software Developer, Consultant, p.iva IT01741850992, hosted by Vevy Europe Advanced Technologies Division. Site created by Raffaele Rialdi, 2009 - 2015 Hosted by: © 2008-2015 Vevy Europe S.p.A. - via Semeria, 16A - 16131 Genova - Italia - P.IVA 00269300109