Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / Tools / WSATConfig / Configuration / FirewallWrapper.cs / 1 / 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- KeyProperty.cs
- GridSplitter.cs
- SafeRegistryHandle.cs
- ManifestResourceInfo.cs
- ByteAnimationBase.cs
- DataGridSortCommandEventArgs.cs
- ProtocolsConfiguration.cs
- coordinator.cs
- LogicalTreeHelper.cs
- RegexInterpreter.cs
- _PooledStream.cs
- WsatServiceCertificate.cs
- CustomExpressionEventArgs.cs
- NumberFunctions.cs
- XmlResolver.cs
- CustomValidator.cs
- ConfigXmlSignificantWhitespace.cs
- DesignerRegion.cs
- BaseComponentEditor.cs
- CredentialCache.cs
- Regex.cs
- RowToFieldTransformer.cs
- Variable.cs
- RightsManagementPermission.cs
- MatrixAnimationUsingKeyFrames.cs
- ErrorEventArgs.cs
- WindowsFormsEditorServiceHelper.cs
- EmptyEnumerator.cs
- MatrixTransform.cs
- WebPartTracker.cs
- KeyEventArgs.cs
- XmlReflectionImporter.cs
- SqlClientMetaDataCollectionNames.cs
- AccessDataSourceWizardForm.cs
- StructuralObject.cs
- ObjectFullSpanRewriter.cs
- EntityDesignPluralizationHandler.cs
- CqlParserHelpers.cs
- SegmentInfo.cs
- XmlSchemaSimpleContentRestriction.cs
- VisualStyleRenderer.cs
- StackSpiller.Temps.cs
- ResourcePart.cs
- ContainsSearchOperator.cs
- UserNamePasswordValidator.cs
- CAGDesigner.cs
- Zone.cs
- KeyValueConfigurationElement.cs
- AliasExpr.cs
- AttachedAnnotation.cs
- XPathNavigatorKeyComparer.cs
- TemplateBindingExpressionConverter.cs
- CounterSetInstanceCounterDataSet.cs
- CodeAttributeDeclaration.cs
- SqlDependencyListener.cs
- TextStore.cs
- PassportAuthentication.cs
- AttachedAnnotation.cs
- ExtractedStateEntry.cs
- ObjectToken.cs
- Condition.cs
- TextReturnReader.cs
- ResolveCompletedEventArgs.cs
- SvcMapFile.cs
- SymmetricKeyWrap.cs
- ListBase.cs
- SqlConnectionFactory.cs
- ToolStripMenuItem.cs
- WindowsBrush.cs
- Point3DAnimationBase.cs
- Codec.cs
- FreezableOperations.cs
- ListViewContainer.cs
- Permission.cs
- DataGridDesigner.cs
- SyndicationSerializer.cs
- XPathSelectionIterator.cs
- OpenTypeLayoutCache.cs
- _ShellExpression.cs
- _PooledStream.cs
- AsyncPostBackTrigger.cs
- DebugManager.cs
- NamespaceQuery.cs
- CheckBox.cs
- DataRow.cs
- BamlResourceDeserializer.cs
- GeneralTransform3D.cs
- FieldAccessException.cs
- UInt64Converter.cs
- ExpressionReplacer.cs
- AutomationPropertyInfo.cs
- DataGridAutomationPeer.cs
- Vector3DCollectionValueSerializer.cs
- ResourceDescriptionAttribute.cs
- SizeChangedInfo.cs
- EntityConnectionStringBuilder.cs
- DataBoundLiteralControl.cs
- CacheSection.cs
- DataSourceSelectArguments.cs
- TableParaClient.cs