Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WCF / Tools / WSATConfig / Configuration / FirewallWrapper.cs / 1305376 / FirewallWrapper.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace Microsoft.Tools.ServiceModel.WsatConfig { using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServices; using System.Collections; using System.Security.Permissions; class FirewallWrapper { const string FwMgrClassId = "{304CE942-6E39-40D8-943A-B913C40C9CD4}"; const string FwOpenPortClassId = "{0CA545C6-37AD-4A6C-BF92-9F7610067EF5}"; INetFirewallMgr manager = null; INetFirewallOpenPortsCollection openPorts = null; INetFirewallPolicy localPolicy = null; INetFirewallProfile currentProfile = null; [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)] internal FirewallWrapper() { try { this.manager = (INetFirewallMgr)Activator.CreateInstance(Type.GetTypeFromCLSID(new Guid(FwMgrClassId))); this.localPolicy = this.manager.LocalPolicy; this.currentProfile = this.localPolicy.CurrentProfile; this.openPorts = this.currentProfile.GloballyOpenPorts; } catch (COMException) { this.manager = null; this.localPolicy = null; this.currentProfile = null; this.openPorts = null; } catch (MethodAccessException ex) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), ex); } } bool IsHttpsPortOpened(int port) { foreach (INetFirewallOpenPort openPort in this.openPorts) { if (openPort.Port == port) { return true; } } return false; } internal void AddHttpsPort(int portToAdd) { // //if portToAdd is already opened, adding it anyway will remove the old entry // if (portToAdd < 0 || this.openPorts == null || IsHttpsPortOpened(portToAdd)) { return; } try { INetFirewallOpenPort openPort = (INetFirewallOpenPort)Activator.CreateInstance(Type.GetTypeFromCLSID(new Guid(FwOpenPortClassId))); openPort.Enabled = true; openPort.IPVersion = NetFirewallIPVersion.Any; openPort.Name = SR.GetString(SR.HTTPSPortName); openPort.Port = portToAdd; openPort.Protocol = NetFirewallIPProtocol.Tcp; openPort.Scope = NetFirewallScope.All; this.openPorts.Add(openPort); } catch (COMException e) { throw new WsatAdminException(WsatAdminErrorCode.UNEXPECTED_FIREWALL_CONFIG_ERROR, SR.GetString(SR.UnexpectedFirewallError, e.Message), e); } catch (MethodAccessException e) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), e); } catch (UnauthorizedAccessException e) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), e); } } internal void RemoveHttpsPort(int portToRemove) { if (portToRemove<0 || this.openPorts == null) { return; } Listports = new List (); foreach (INetFirewallOpenPort port in this.openPorts) { if (port.Port == portToRemove && Utilities.SafeCompare(port.Name, SR.GetString(SR.HTTPSPortName))) { ports.Add(port); // continue to remove other ports under the WSAT port name to minimize security attack // surface for the machine, but throw out an exception in the end } } bool accessDenied = false; foreach (INetFirewallOpenPort port in ports) { try { this.openPorts.Remove(port.Port, port.Protocol); } catch (UnauthorizedAccessException) { accessDenied = true; } } if (accessDenied) { // at least one port could not be removed due to permission denied throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied)); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace Microsoft.Tools.ServiceModel.WsatConfig { using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServices; using System.Collections; using System.Security.Permissions; class FirewallWrapper { const string FwMgrClassId = "{304CE942-6E39-40D8-943A-B913C40C9CD4}"; const string FwOpenPortClassId = "{0CA545C6-37AD-4A6C-BF92-9F7610067EF5}"; INetFirewallMgr manager = null; INetFirewallOpenPortsCollection openPorts = null; INetFirewallPolicy localPolicy = null; INetFirewallProfile currentProfile = null; [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)] internal FirewallWrapper() { try { this.manager = (INetFirewallMgr)Activator.CreateInstance(Type.GetTypeFromCLSID(new Guid(FwMgrClassId))); this.localPolicy = this.manager.LocalPolicy; this.currentProfile = this.localPolicy.CurrentProfile; this.openPorts = this.currentProfile.GloballyOpenPorts; } catch (COMException) { this.manager = null; this.localPolicy = null; this.currentProfile = null; this.openPorts = null; } catch (MethodAccessException ex) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), ex); } } bool IsHttpsPortOpened(int port) { foreach (INetFirewallOpenPort openPort in this.openPorts) { if (openPort.Port == port) { return true; } } return false; } internal void AddHttpsPort(int portToAdd) { // //if portToAdd is already opened, adding it anyway will remove the old entry // if (portToAdd < 0 || this.openPorts == null || IsHttpsPortOpened(portToAdd)) { return; } try { INetFirewallOpenPort openPort = (INetFirewallOpenPort)Activator.CreateInstance(Type.GetTypeFromCLSID(new Guid(FwOpenPortClassId))); openPort.Enabled = true; openPort.IPVersion = NetFirewallIPVersion.Any; openPort.Name = SR.GetString(SR.HTTPSPortName); openPort.Port = portToAdd; openPort.Protocol = NetFirewallIPProtocol.Tcp; openPort.Scope = NetFirewallScope.All; this.openPorts.Add(openPort); } catch (COMException e) { throw new WsatAdminException(WsatAdminErrorCode.UNEXPECTED_FIREWALL_CONFIG_ERROR, SR.GetString(SR.UnexpectedFirewallError, e.Message), e); } catch (MethodAccessException e) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), e); } catch (UnauthorizedAccessException e) { throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied), e); } } internal void RemoveHttpsPort(int portToRemove) { if (portToRemove<0 || this.openPorts == null) { return; } List ports = new List (); foreach (INetFirewallOpenPort port in this.openPorts) { if (port.Port == portToRemove && Utilities.SafeCompare(port.Name, SR.GetString(SR.HTTPSPortName))) { ports.Add(port); // continue to remove other ports under the WSAT port name to minimize security attack // surface for the machine, but throw out an exception in the end } } bool accessDenied = false; foreach (INetFirewallOpenPort port in ports) { try { this.openPorts.Remove(port.Port, port.Protocol); } catch (UnauthorizedAccessException) { accessDenied = true; } } if (accessDenied) { // at least one port could not be removed due to permission denied throw new WsatAdminException(WsatAdminErrorCode.FIREWALL_ACCESS_DENIED, SR.GetString(SR.FirewallAccessDenied)); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CacheRequest.cs
- EditorServiceContext.cs
- ImageClickEventArgs.cs
- Globals.cs
- DataGridClipboardHelper.cs
- TraceSwitch.cs
- ByteAnimationBase.cs
- SelectorAutomationPeer.cs
- ObjectDataSourceEventArgs.cs
- PersonalizationProviderHelper.cs
- PackageStore.cs
- BasicExpressionVisitor.cs
- FormatSettings.cs
- DbConnectionOptions.cs
- ISO2022Encoding.cs
- IssuedTokenServiceElement.cs
- SplitterCancelEvent.cs
- C14NUtil.cs
- EnvelopedSignatureTransform.cs
- Variable.cs
- StateRuntime.cs
- ModuleBuilderData.cs
- DrawingBrush.cs
- ListViewTableRow.cs
- SafeFindHandle.cs
- Int32AnimationBase.cs
- RightNameExpirationInfoPair.cs
- FrameSecurityDescriptor.cs
- LocatorBase.cs
- PersianCalendar.cs
- SqlDelegatedTransaction.cs
- OracleDataAdapter.cs
- Context.cs
- CommonDialog.cs
- Asn1IntegerConverter.cs
- GeneralTransform3DGroup.cs
- MDIWindowDialog.cs
- WindowsContainer.cs
- DbParameterCollection.cs
- WorkflowPageSetupDialog.cs
- ObjectStateEntryBaseUpdatableDataRecord.cs
- AsymmetricAlgorithm.cs
- PointLightBase.cs
- DurationConverter.cs
- AutomationElementCollection.cs
- Button.cs
- DatePickerAutomationPeer.cs
- TreeNodeConverter.cs
- QueryableDataSourceEditData.cs
- FramingFormat.cs
- DesignerPainter.cs
- RequestQueue.cs
- AnnotationDocumentPaginator.cs
- MethodExpr.cs
- XmlEncoding.cs
- FormViewModeEventArgs.cs
- UIHelper.cs
- CommentEmitter.cs
- Vector3DConverter.cs
- MetricEntry.cs
- Point3DCollection.cs
- DecodeHelper.cs
- LocatorBase.cs
- BindingCollection.cs
- AppDomainShutdownMonitor.cs
- MemberHolder.cs
- SQLMembershipProvider.cs
- SqlRemoveConstantOrderBy.cs
- ConfigXmlWhitespace.cs
- PropertyEmitterBase.cs
- FlowLayoutPanelDesigner.cs
- FontSourceCollection.cs
- CannotUnloadAppDomainException.cs
- SqlProfileProvider.cs
- objectquery_tresulttype.cs
- FixedSOMTextRun.cs
- CodeGenerator.cs
- ViewGenerator.cs
- TdsParser.cs
- DateTimeOffsetConverter.cs
- _ConnectStream.cs
- HelloOperationCD1AsyncResult.cs
- GridViewColumnCollection.cs
- Timeline.cs
- DataStreams.cs
- IgnoreSectionHandler.cs
- EpmContentDeSerializer.cs
- TableLayoutStyleCollection.cs
- CssStyleCollection.cs
- Misc.cs
- IPEndPoint.cs
- GrammarBuilderWildcard.cs
- RenderOptions.cs
- FileSecurity.cs
- ObjectDataSourceEventArgs.cs
- LineVisual.cs
- UmAlQuraCalendar.cs
- DiffuseMaterial.cs
- Point.cs
- ProcessModule.cs