| /* |
| * Copyright 2007 Jeff Latimer |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library 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 |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA |
| * |
| ***************************************************************************** |
| * |
| * The firewall management interface |
| * |
| */ |
| |
| import "icftypes.idl"; |
| import "oaidl.idl"; |
| |
| [ |
| object, |
| uuid(A6207B2E-7CDD-426A-951E-5E1CBC5AFEAD), |
| dual |
| ] |
| interface INetFwIcmpSettings : IDispatch |
| { |
| [id(1), propget] |
| HRESULT AllowOutboundDestinationUnreachable([out, retval] VARIANT_BOOL* allow); |
| |
| [id(1), propput] |
| HRESULT AllowOutboundDestinationUnreachable( [in] VARIANT_BOOL allow ); |
| |
| [id(2), propget] |
| HRESULT AllowRedirect( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(2), propput] |
| HRESULT AllowRedirect( [in] VARIANT_BOOL allow ); |
| |
| [id(3), propget] |
| HRESULT AllowInboundEchoRequest( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(3), propput] |
| HRESULT AllowInboundEchoRequest( [in] VARIANT_BOOL allow ); |
| |
| [id(4), propget] |
| HRESULT AllowOutboundTimeExceeded( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(4), propput] |
| HRESULT AllowOutboundTimeExceeded( [in] VARIANT_BOOL allow ); |
| |
| [id(5), propget] |
| HRESULT AllowOutboundParameterProblem( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(5), propput] |
| HRESULT AllowOutboundParameterProblem( [in] VARIANT_BOOL allow ); |
| |
| [id(6), propget] |
| HRESULT AllowOutboundSourceQuench( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(6), propput] |
| HRESULT AllowOutboundSourceQuench( [in] VARIANT_BOOL allow ); |
| |
| [id(7), propget] |
| HRESULT AllowInboundRouterRequest( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(7), propput] |
| HRESULT AllowInboundRouterRequest( [in] VARIANT_BOOL allow ); |
| |
| [id(8), propget] |
| HRESULT AllowInboundTimestampRequest( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(8), propput] |
| HRESULT AllowInboundTimestampRequest( [in] VARIANT_BOOL allow ); |
| |
| [id(9), propget] |
| HRESULT AllowInboundMaskRequest( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(9), propput] |
| HRESULT AllowInboundMaskRequest( [in] VARIANT_BOOL allow ); |
| |
| [id(10), propget] |
| HRESULT AllowOutboundPacketTooBig( [out, retval] VARIANT_BOOL* allow ); |
| |
| [id(10), propput] |
| HRESULT AllowOutboundPacketTooBig( [in] VARIANT_BOOL allow ); |
| } |
| |
| [ |
| object, |
| uuid(E0483BA0-47FF-4D9C-A6D6-7741D0B195F7), |
| dual |
| ] |
| interface INetFwOpenPort : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Name( [out, retval] BSTR* name ); |
| |
| [id(1), propput] |
| HRESULT Name( [in] BSTR name ); |
| |
| [id(2), propget] |
| HRESULT IpVersion( [out, retval] NET_FW_IP_VERSION* ipVersion ); |
| |
| [id(2), propput] |
| HRESULT IpVersion( [in] NET_FW_IP_VERSION ipVersion ); |
| |
| [id(3), propget] |
| HRESULT Protocol( [out, retval] NET_FW_IP_PROTOCOL* ipProtocol ); |
| |
| [id(3), propput] |
| HRESULT Protocol( [in] NET_FW_IP_PROTOCOL ipProtocol ); |
| |
| [id(4), propget] |
| HRESULT Port( [out, retval] LONG* portNumber ); |
| |
| [id(4), propput] |
| HRESULT Port( [in] LONG portNumber ); |
| |
| [id(5), propget] |
| HRESULT Scope( [out, retval] NET_FW_SCOPE* scope ); |
| |
| [id(5), propput] |
| HRESULT Scope( [in] NET_FW_SCOPE scope ); |
| |
| [id(6), propget] |
| HRESULT RemoteAddresses( [out, retval] BSTR* remoteAddrs ); |
| |
| [id(6), propput] |
| HRESULT RemoteAddresses( [in] BSTR remoteAddrs ); |
| |
| [id(7), propget] |
| HRESULT Enabled( [out, retval] VARIANT_BOOL* enabled ); |
| |
| [id(7), propput] |
| HRESULT Enabled( [in] VARIANT_BOOL enabled ); |
| |
| [id(8), propget] |
| HRESULT BuiltIn( [out, retval] VARIANT_BOOL* builtIn ); |
| } |
| |
| [ |
| object, |
| uuid(C0E9D7FA-E07E-430A-B19A-090CE82D92E2), |
| dual |
| ] |
| interface INetFwOpenPorts : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Count( [out, retval] long* count ); |
| |
| [id(2)] |
| HRESULT Add( [in] INetFwOpenPort* port ); |
| |
| [id(3)] |
| HRESULT Remove( [in] LONG portNumber, [in] NET_FW_IP_PROTOCOL ipProtocol ); |
| |
| [id(4)] |
| HRESULT Item( [in] LONG portNumber, [in] NET_FW_IP_PROTOCOL ipProtocol, |
| [out, retval] INetFwOpenPort** openPort ); |
| |
| [id(DISPID_NEWENUM), propget, restricted] |
| HRESULT _NewEnum( [out, retval] IUnknown** newEnum ); |
| } |
| |
| [ |
| object, |
| uuid(79FD57C8-908E-4A36-9888-D5B3F0A444CF), |
| dual |
| ] |
| interface INetFwService : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Name( [out, retval] BSTR* name ); |
| |
| [id(2), propget] |
| HRESULT Type( [out, retval] NET_FW_SERVICE_TYPE* type ); |
| |
| [id(3), propget] |
| HRESULT Customized( [out, retval] VARIANT_BOOL* customized ); |
| |
| [id(4), propget] |
| HRESULT IpVersion( [out, retval] NET_FW_IP_VERSION* ipVersion ); |
| |
| [id(4), propput] |
| HRESULT IpVersion( [in] NET_FW_IP_VERSION ipVersion ); |
| |
| [id(5), propget] |
| HRESULT Scope( [out, retval] NET_FW_SCOPE* scope ); |
| |
| [id(5), propput] |
| HRESULT Scope( [in] NET_FW_SCOPE scope ); |
| |
| [id(6), propget] |
| HRESULT RemoteAddresses( [out, retval] BSTR* remoteAddrs ); |
| |
| [id(6), propput] |
| HRESULT RemoteAddresses( [in] BSTR remoteAddrs ); |
| |
| [id(7), propget] |
| HRESULT Enabled( [out, retval] VARIANT_BOOL* enabled ); |
| |
| [id(7), propput] |
| HRESULT Enabled( [in] VARIANT_BOOL enabled ); |
| |
| [id(8), propget] |
| HRESULT GloballyOpenPorts( [out, retval] INetFwOpenPorts** openPorts ); |
| } |
| |
| [ |
| object, |
| uuid(79649BB4-903E-421B-94C9-79848E79F6EE), |
| dual |
| ] |
| interface INetFwServices : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Count( [out, retval] long* count ); |
| |
| [id(2)] |
| HRESULT Item( [in] NET_FW_SERVICE_TYPE svcType, |
| [out, retval] INetFwService** service ); |
| |
| [id(DISPID_NEWENUM), propget, restricted] |
| HRESULT _NewEnum( [out, retval] IUnknown** newEnum ); |
| } |
| |
| [ |
| object, |
| uuid(B5E64FFA-C2C5-444E-A301-FB5E00018050), |
| dual |
| ] |
| interface INetFwAuthorizedApplication : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Name( [out, retval] BSTR* name ); |
| |
| [id(1), propput] |
| HRESULT Name( [in] BSTR name ); |
| |
| [id(2), propget] |
| HRESULT ProcessImageFileName( [out, retval] BSTR* imageFileName ); |
| |
| [id(2), propput] |
| HRESULT ProcessImageFileName( [in] BSTR imageFileName ); |
| |
| [id(3), propget] |
| HRESULT IpVersion( [out, retval] NET_FW_IP_VERSION* ipVersion ); |
| |
| [id(3), propput] |
| HRESULT IpVersion( [in] NET_FW_IP_VERSION ipVersion ); |
| |
| [id(4), propget] |
| HRESULT Scope( [out, retval] NET_FW_SCOPE* scope ); |
| |
| [id(4), propput] |
| HRESULT Scope( [in] NET_FW_SCOPE scope ); |
| |
| [id(5), propget] |
| HRESULT RemoteAddresses( [out, retval] BSTR* remoteAddrs ); |
| |
| [id(5), propput] |
| HRESULT RemoteAddresses( [in] BSTR remoteAddrs ); |
| |
| [id(6), propget] |
| HRESULT Enabled( [out, retval] VARIANT_BOOL* enabled ); |
| |
| [id(6), propput] |
| HRESULT Enabled( [in] VARIANT_BOOL enabled ); |
| } |
| |
| [ |
| object, |
| uuid(D4BECDDF-6F73-4A83-B832-9C66874CD20E), |
| dual |
| ] |
| interface INetFwRemoteAdminSettings : IDispatch |
| { |
| [id(1), propget] |
| HRESULT IpVersion( [out, retval] NET_FW_IP_VERSION* ipVersion ); |
| |
| [id(1), propput] |
| HRESULT IpVersion( [in] NET_FW_IP_VERSION ipVersion ); |
| |
| [id(2), propget] |
| HRESULT Scope( [out, retval] NET_FW_SCOPE* scope ); |
| |
| [id(2), propput] |
| HRESULT Scope( [in] NET_FW_SCOPE scope ); |
| |
| [id(3), propget] |
| HRESULT RemoteAddresses( [out, retval] BSTR* remoteAddrs ); |
| |
| [id(3), propput] |
| HRESULT RemoteAddresses( [in] BSTR remoteAddrs ); |
| |
| [id(4), propget] |
| HRESULT Enabled( [out, retval] VARIANT_BOOL* enabled ); |
| |
| [id(4), propput] |
| HRESULT Enabled( [in] VARIANT_BOOL enabled ); |
| } |
| |
| |
| [ |
| object, |
| uuid(644EFD52-CCF9-486C-97A2-39F352570B30), |
| dual |
| ] |
| interface INetFwAuthorizedApplications : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Count( [out, retval] long* count ); |
| |
| [id(2)] |
| HRESULT Add( [in] INetFwAuthorizedApplication* app ); |
| |
| [id(3)] |
| HRESULT Remove( [in] BSTR imageFileName ); |
| |
| [id(4)] |
| HRESULT Item( [in] BSTR imageFileName, |
| [out, retval] INetFwAuthorizedApplication** app ); |
| |
| [id(DISPID_NEWENUM), propget, restricted] |
| HRESULT _NewEnum( [out, retval] IUnknown** newEnum ); |
| } |
| |
| [ |
| object, |
| uuid(174A0DDA-E9F9-449D-993B-21AB667CA456), |
| dual |
| ] |
| interface INetFwProfile : IDispatch |
| { |
| [id(1), propget] |
| HRESULT Type( [out, retval] NET_FW_PROFILE_TYPE* type ); |
| |
| [id(2), propget] |
| HRESULT FirewallEnabled( [out, retval] VARIANT_BOOL* enabled ); |
| |
| [id(2), propput] |
| HRESULT FirewallEnabled( [in] VARIANT_BOOL enabled ); |
| |
| [id(3), propget] |
| HRESULT ExceptionsNotAllowed( [out, retval] VARIANT_BOOL* notAllowed ); |
| |
| [id(3), propput] |
| HRESULT ExceptionsNotAllowed( [in] VARIANT_BOOL notAllowed ); |
| |
| [id(4), propget] |
| HRESULT NotificationsDisabled( [out, retval] VARIANT_BOOL* disabled ); |
| |
| [id(4), propput] |
| HRESULT NotificationsDisabled( [in] VARIANT_BOOL disabled ); |
| |
| [id(5), propget] |
| HRESULT UnicastResponsesToMulticastBroadcastDisabled( [out, retval] VARIANT_BOOL* disabled ); |
| |
| [id(5), propput] |
| HRESULT UnicastResponsesToMulticastBroadcastDisabled( [in] VARIANT_BOOL disabled ); |
| |
| [id(6), propget] |
| HRESULT RemoteAdminSettings( [out, retval] INetFwRemoteAdminSettings** remoteAdminSettings ); |
| |
| [id(7), propget] |
| HRESULT IcmpSettings( [out, retval] INetFwIcmpSettings** icmpSettings ); |
| |
| [id(8), propget] |
| HRESULT GloballyOpenPorts( [out, retval] INetFwOpenPorts** openPorts ); |
| |
| [id(9), propget] |
| HRESULT Services( [out, retval] INetFwServices** services ); |
| |
| [id(10), propget] |
| HRESULT AuthorizedApplications( [out, retval] INetFwAuthorizedApplications** apps ); |
| } |
| |
| [ |
| object, |
| uuid(D46D2478-9AC9-4008-9DC7-5563CE5536CC), |
| dual |
| ] |
| interface INetFwPolicy : IDispatch |
| { |
| [id(1), propget] |
| HRESULT CurrentProfile( [out, retval] INetFwProfile** profile ); |
| |
| [id(2)] |
| HRESULT GetProfileByType( [in] NET_FW_PROFILE_TYPE profileType, |
| [out, retval] INetFwProfile** profile ); |
| } |
| |
| [ |
| object, |
| uuid(F7898AF5-CAC4-4632-A2EC-DA06E5111AF2), |
| dual |
| ] |
| interface INetFwMgr : IDispatch |
| { |
| [id(1), propget] |
| HRESULT LocalPolicy( [out, retval] INetFwPolicy** localPolicy ); |
| |
| [id(2), propget] |
| HRESULT CurrentProfileType( [out, retval] NET_FW_PROFILE_TYPE* profileType ); |
| |
| [id(3)] |
| HRESULT RestoreDefaults(); |
| |
| [id(4)] |
| HRESULT IsPortAllowed( [in] BSTR imageFileName, [in] NET_FW_IP_VERSION ipVersion, |
| [in] LONG portNumber, [in] BSTR localAddress, |
| [in] NET_FW_IP_PROTOCOL ipProtocol, [out] VARIANT* allowed, |
| [out] VARIANT* restricted ); |
| |
| [id(5)] |
| HRESULT IsIcmpTypeAllowed( [in] NET_FW_IP_VERSION ipVersion, [in] BSTR localAddress, |
| [in] BYTE type, [out] VARIANT* allowed, |
| [out] VARIANT* restricted ); |
| } |
| |
| [ |
| uuid(DB4F3345-3EF8-45ED-B976-25A6D3B81B71), |
| version(1.0) |
| ] |
| library NetFwPublicTypeLib |
| { |
| importlib("stdole2.tlb"); |
| interface INetFwRemoteAdminSettings; |
| interface INetFwIcmpSettings; |
| interface INetFwOpenPort; |
| interface INetFwOpenPorts; |
| interface INetFwService; |
| interface INetFwServices; |
| interface INetFwAuthorizedApplication; |
| interface INetFwAuthorizedApplications; |
| interface INetFwProfile; |
| interface INetFwPolicy; |
| interface INetFwMgr; |
| |
| [ |
| uuid(0CA545C6-37AD-4A6C-BF92-9F7610067EF5) |
| ] |
| coclass NetFwOpenPort |
| { |
| [default] interface INetFwOpenPort; |
| } |
| |
| [ |
| uuid(EC9846B3-2762-4A6B-A214-6ACB603462D2) |
| ] |
| coclass NetFwAuthorizedApplication |
| { |
| [default] interface INetFwAuthorizedApplication; |
| } |
| |
| [ |
| uuid(304CE942-6E39-40D8-943A-B913C40C9CD4) |
| ] |
| coclass NetFwMgr |
| { |
| [default] interface INetFwMgr; |
| } |
| } |