Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Net / System / Net / NetworkInformation / SystemIPAddressInformation.cs / 1305376 / SystemIPAddressInformation.cs
////// namespace System.Net.NetworkInformation { using System.Net; using System.Net.Sockets; using System; using System.Runtime.InteropServices; using System.Collections; using System.ComponentModel; using System.Security.Permissions; using Microsoft.Win32; //this is the main addressinformation class that contains the ipaddress //and other properties internal class SystemIPAddressInformation:IPAddressInformation{ IPAddress address; internal bool transient = false; internal bool dnsEligible = true; /* // Consider removing. internal SystemIPAddressInformation(){} */ internal SystemIPAddressInformation(IPAddress address) { this.address = address; if (address.AddressFamily == AddressFamily.InterNetwork) { //DngEligible is true except for 169.254.x.x addresses (the APIPA addresses ) dnsEligible = !((address.m_Address & 0x0000FEA9)>0); } } internal SystemIPAddressInformation(IpAdapterUnicastAddress adapterAddress,IPAddress address) { this.address = address; transient = (adapterAddress.flags & AdapterAddressFlags.Transient)>0; dnsEligible = (adapterAddress.flags & AdapterAddressFlags.DnsEligible)>0; } internal SystemIPAddressInformation(IpAdapterAddress adapterAddress,IPAddress address) { this.address = address; transient = (adapterAddress.flags & AdapterAddressFlags.Transient)>0; dnsEligible = (adapterAddress.flags & AdapterAddressFlags.DnsEligible)>0; } public override IPAddress Address{get {return address;}} /// /// Provides support for ip configuation information and statistics. /// The address is a cluster address and shouldn't be used by most applications. public override bool IsTransient{ get { return (transient); } } ///This address can be used for DNS. public override bool IsDnsEligible{ get { return (dnsEligible); } } //helper method that marshals the addressinformation into the classes internal static IPAddressCollection ToAddressCollection(IntPtr ptr,IPVersion versionSupported) { //we don't know the number of addresses up front, so we create an arraylist //to temporarily store them. IPAddressCollection addressList = new IPAddressCollection(); //if there is no address, just return; if (ptr == IntPtr.Zero) return addressList; //get the first address IpAdapterAddress addr = (IpAdapterAddress)Marshal.PtrToStructure(ptr,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress AddressFamily family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; SocketAddress sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //unfortunately, the only way to currently create an ipaddress is through IPEndPoint IPEndPoint ep; if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); //add the ipaddress to the arraylist addressList.InternalAdd(ep.Address); //repeat for all of the addresses while ( addr.next != IntPtr.Zero ) { addr = (IpAdapterAddress)Marshal.PtrToStructure(addr.next,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; //only add addresses that are the same type as what is supported by the interface //this fixes a bug in iphelper regarding dns addresses if (((family == AddressFamily.InterNetwork) && ((versionSupported & IPVersion.IPv4) > 0)) || ((family == AddressFamily.InterNetworkV6) && ((versionSupported & IPVersion.IPv6) > 0))) { sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //use the endpoint to create the ipaddress if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); addressList.InternalAdd(ep.Address); } } return addressList; } //helper method that marshals the addressinformation into the classes internal static IPAddressInformationCollection ToAddressInformationCollection(IntPtr ptr,IPVersion versionSupported) { //we don't know the number of addresses up front, so we create an arraylist //to temporarily store them. IPAddressInformationCollection addressList = new IPAddressInformationCollection(); //if there is no address, just return; if (ptr == IntPtr.Zero) return addressList; //get the first address IpAdapterAddress addr = (IpAdapterAddress)Marshal.PtrToStructure(ptr,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress AddressFamily family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; SocketAddress sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //unfortunately, the only way to currently create an ipaddress is through IPEndPoint IPEndPoint ep; if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); //add the ipaddress to the arraylist addressList.InternalAdd(new SystemIPAddressInformation(addr,ep.Address)); //repeat for all of the addresses while ( addr.next != IntPtr.Zero ) { addr = (IpAdapterAddress)Marshal.PtrToStructure(addr.next,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; //only add addresses that are the same type as what is supported by the interface //this fixes a bug in iphelper regarding dns addresses if (((family == AddressFamily.InterNetwork) && ((versionSupported & IPVersion.IPv4) > 0)) || ((family == AddressFamily.InterNetworkV6) && ((versionSupported & IPVersion.IPv6) > 0))) { sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //use the endpoint to create the ipaddress if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); addressList.InternalAdd(new SystemIPAddressInformation(addr,ep.Address)); } } return addressList; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. ////// namespace System.Net.NetworkInformation { using System.Net; using System.Net.Sockets; using System; using System.Runtime.InteropServices; using System.Collections; using System.ComponentModel; using System.Security.Permissions; using Microsoft.Win32; //this is the main addressinformation class that contains the ipaddress //and other properties internal class SystemIPAddressInformation:IPAddressInformation{ IPAddress address; internal bool transient = false; internal bool dnsEligible = true; /* // Consider removing. internal SystemIPAddressInformation(){} */ internal SystemIPAddressInformation(IPAddress address) { this.address = address; if (address.AddressFamily == AddressFamily.InterNetwork) { //DngEligible is true except for 169.254.x.x addresses (the APIPA addresses ) dnsEligible = !((address.m_Address & 0x0000FEA9)>0); } } internal SystemIPAddressInformation(IpAdapterUnicastAddress adapterAddress,IPAddress address) { this.address = address; transient = (adapterAddress.flags & AdapterAddressFlags.Transient)>0; dnsEligible = (adapterAddress.flags & AdapterAddressFlags.DnsEligible)>0; } internal SystemIPAddressInformation(IpAdapterAddress adapterAddress,IPAddress address) { this.address = address; transient = (adapterAddress.flags & AdapterAddressFlags.Transient)>0; dnsEligible = (adapterAddress.flags & AdapterAddressFlags.DnsEligible)>0; } public override IPAddress Address{get {return address;}} /// /// Provides support for ip configuation information and statistics. /// The address is a cluster address and shouldn't be used by most applications. public override bool IsTransient{ get { return (transient); } } ///This address can be used for DNS. public override bool IsDnsEligible{ get { return (dnsEligible); } } //helper method that marshals the addressinformation into the classes internal static IPAddressCollection ToAddressCollection(IntPtr ptr,IPVersion versionSupported) { //we don't know the number of addresses up front, so we create an arraylist //to temporarily store them. IPAddressCollection addressList = new IPAddressCollection(); //if there is no address, just return; if (ptr == IntPtr.Zero) return addressList; //get the first address IpAdapterAddress addr = (IpAdapterAddress)Marshal.PtrToStructure(ptr,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress AddressFamily family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; SocketAddress sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //unfortunately, the only way to currently create an ipaddress is through IPEndPoint IPEndPoint ep; if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); //add the ipaddress to the arraylist addressList.InternalAdd(ep.Address); //repeat for all of the addresses while ( addr.next != IntPtr.Zero ) { addr = (IpAdapterAddress)Marshal.PtrToStructure(addr.next,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; //only add addresses that are the same type as what is supported by the interface //this fixes a bug in iphelper regarding dns addresses if (((family == AddressFamily.InterNetwork) && ((versionSupported & IPVersion.IPv4) > 0)) || ((family == AddressFamily.InterNetworkV6) && ((versionSupported & IPVersion.IPv6) > 0))) { sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //use the endpoint to create the ipaddress if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); addressList.InternalAdd(ep.Address); } } return addressList; } //helper method that marshals the addressinformation into the classes internal static IPAddressInformationCollection ToAddressInformationCollection(IntPtr ptr,IPVersion versionSupported) { //we don't know the number of addresses up front, so we create an arraylist //to temporarily store them. IPAddressInformationCollection addressList = new IPAddressInformationCollection(); //if there is no address, just return; if (ptr == IntPtr.Zero) return addressList; //get the first address IpAdapterAddress addr = (IpAdapterAddress)Marshal.PtrToStructure(ptr,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress AddressFamily family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; SocketAddress sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //unfortunately, the only way to currently create an ipaddress is through IPEndPoint IPEndPoint ep; if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); //add the ipaddress to the arraylist addressList.InternalAdd(new SystemIPAddressInformation(addr,ep.Address)); //repeat for all of the addresses while ( addr.next != IntPtr.Zero ) { addr = (IpAdapterAddress)Marshal.PtrToStructure(addr.next,typeof(IpAdapterAddress)); //determine the address family used to create the IPAddress family = (addr.address.addressLength > 16)?AddressFamily.InterNetworkV6:AddressFamily.InterNetwork; //only add addresses that are the same type as what is supported by the interface //this fixes a bug in iphelper regarding dns addresses if (((family == AddressFamily.InterNetwork) && ((versionSupported & IPVersion.IPv4) > 0)) || ((family == AddressFamily.InterNetworkV6) && ((versionSupported & IPVersion.IPv6) > 0))) { sockAddress = new SocketAddress(family,(int)addr.address.addressLength); Marshal.Copy(addr.address.address,sockAddress.m_Buffer,0,addr.address.addressLength); //use the endpoint to create the ipaddress if (family == AddressFamily.InterNetwork ) ep = (IPEndPoint)IPEndPoint.Any.Create(sockAddress); else ep = (IPEndPoint)IPEndPoint.IPv6Any.Create(sockAddress); addressList.InternalAdd(new SystemIPAddressInformation(addr,ep.Address)); } } return addressList; } } } // 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
- RangeValidator.cs
- DataGridViewCellStyleChangedEventArgs.cs
- XXXInfos.cs
- DefaultValueConverter.cs
- SmiRequestExecutor.cs
- Point3DAnimationUsingKeyFrames.cs
- AcceleratedTokenProvider.cs
- BaseParaClient.cs
- EditBehavior.cs
- StylusPointPropertyInfo.cs
- VectorCollectionValueSerializer.cs
- TextTreeText.cs
- LocalIdKeyIdentifierClause.cs
- WaitHandleCannotBeOpenedException.cs
- LinqDataSourceContextEventArgs.cs
- PolygonHotSpot.cs
- CodeDOMProvider.cs
- ObjectToModelValueConverter.cs
- GridViewRowPresenterBase.cs
- TemplateBamlRecordReader.cs
- DriveNotFoundException.cs
- DataServiceContext.cs
- AppDomainAttributes.cs
- GZipUtils.cs
- ActivityMarkupSerializer.cs
- ImageListStreamer.cs
- RelationshipNavigation.cs
- EntityException.cs
- CodeGen.cs
- BinaryWriter.cs
- MonthCalendarDesigner.cs
- ParagraphVisual.cs
- LinqDataSourceHelper.cs
- ProjectionPlanCompiler.cs
- KeyValueInternalCollection.cs
- RadioButtonPopupAdapter.cs
- HostingEnvironmentException.cs
- CfgParser.cs
- DesignerActionPropertyItem.cs
- JsonEncodingStreamWrapper.cs
- Thickness.cs
- Calendar.cs
- ToolTipAutomationPeer.cs
- RectangleGeometry.cs
- CollectionTraceRecord.cs
- HttpHostedTransportConfiguration.cs
- RegexCode.cs
- FixedDocument.cs
- ImageBrush.cs
- shaperfactoryquerycacheentry.cs
- UserPreferenceChangedEventArgs.cs
- IProvider.cs
- XPathSelectionIterator.cs
- PropertyPathWorker.cs
- ControlCodeDomSerializer.cs
- CompositeScriptReference.cs
- ToolStripPanelDesigner.cs
- ThreadAbortException.cs
- LineInfo.cs
- MouseEvent.cs
- UnsafeNativeMethods.cs
- Grammar.cs
- UserControl.cs
- SchemaTypeEmitter.cs
- Misc.cs
- ConstructorBuilder.cs
- DbParameterHelper.cs
- SerializationObjectManager.cs
- XmlStreamStore.cs
- GlyphManager.cs
- ActiveXContainer.cs
- ContainerUtilities.cs
- ProxyWebPartManager.cs
- DataGridDetailsPresenter.cs
- BinaryObjectReader.cs
- EntityViewGenerationAttribute.cs
- PeerDefaultCustomResolverClient.cs
- GraphicsContainer.cs
- ConstraintManager.cs
- WebPartConnectVerb.cs
- CategoryAttribute.cs
- DynamicILGenerator.cs
- EntityReference.cs
- DynamicILGenerator.cs
- ObjectStorage.cs
- DocumentOrderQuery.cs
- CqlErrorHelper.cs
- ToolStripSettings.cs
- SchemaDeclBase.cs
- NotSupportedException.cs
- XPathDocumentBuilder.cs
- ManifestResourceInfo.cs
- LayoutEditorPart.cs
- SchemaAttDef.cs
- SqlConnectionFactory.cs
- DashStyle.cs
- CalloutQueueItem.cs
- CrossAppDomainChannel.cs
- ListBase.cs
- FileLevelControlBuilderAttribute.cs