|  | @@ -1,290 +0,0 @@
 | 
	
		
			
				|  |  | -using MediaBrowser.Common.Net;
 | 
	
		
			
				|  |  | -using MediaBrowser.Model.Net;
 | 
	
		
			
				|  |  | -using System;
 | 
	
		
			
				|  |  | -using System.Collections.Generic;
 | 
	
		
			
				|  |  | -using System.Globalization;
 | 
	
		
			
				|  |  | -using System.Linq;
 | 
	
		
			
				|  |  | -using System.Net;
 | 
	
		
			
				|  |  | -using System.Net.NetworkInformation;
 | 
	
		
			
				|  |  | -using System.Net.Sockets;
 | 
	
		
			
				|  |  | -using System.Runtime.InteropServices;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -namespace MediaBrowser.Common.Implementations.NetworkManagement
 | 
	
		
			
				|  |  | -{
 | 
	
		
			
				|  |  | -    /// <summary>
 | 
	
		
			
				|  |  | -    /// Class NetUtils
 | 
	
		
			
				|  |  | -    /// </summary>
 | 
	
		
			
				|  |  | -    public class NetworkManager : INetworkManager
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Gets the machine's local ip address
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <returns>IPAddress.</returns>
 | 
	
		
			
				|  |  | -        public IEnumerable<string> GetLocalIpAddresses()
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            var host = Dns.GetHostEntry(Dns.GetHostName());
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            // Reverse them because the last one is usually the correct one
 | 
	
		
			
				|  |  | -            // It's not fool-proof so ultimately the consumer will have to examine them and decide
 | 
	
		
			
				|  |  | -            return host.AddressList
 | 
	
		
			
				|  |  | -                .Where(i => i.AddressFamily == AddressFamily.InterNetwork)
 | 
	
		
			
				|  |  | -                .Select(i => i.ToString())
 | 
	
		
			
				|  |  | -                .Reverse();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Gets a random port number that is currently available
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <returns>System.Int32.</returns>
 | 
	
		
			
				|  |  | -        public int GetRandomUnusedPort()
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            var listener = new TcpListener(IPAddress.Any, 0);
 | 
	
		
			
				|  |  | -            listener.Start();
 | 
	
		
			
				|  |  | -            var port = ((IPEndPoint)listener.LocalEndpoint).Port;
 | 
	
		
			
				|  |  | -            listener.Stop();
 | 
	
		
			
				|  |  | -            return port;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Returns MAC Address from first Network Card in Computer
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <returns>[string] MAC Address</returns>
 | 
	
		
			
				|  |  | -        public string GetMacAddress()
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return NetworkInterface.GetAllNetworkInterfaces()
 | 
	
		
			
				|  |  | -                .Where(i => i.NetworkInterfaceType != NetworkInterfaceType.Loopback)
 | 
	
		
			
				|  |  | -                .Select(i => BitConverter.ToString(i.GetPhysicalAddress().GetAddressBytes()))
 | 
	
		
			
				|  |  | -                .FirstOrDefault();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Gets the network shares.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="path">The path.</param>
 | 
	
		
			
				|  |  | -        /// <returns>IEnumerable{NetworkShare}.</returns>
 | 
	
		
			
				|  |  | -        public IEnumerable<NetworkShare> GetNetworkShares(string path)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new ShareCollection(path).OfType<Share>().Select(ToNetworkShare);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// To the network share.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="share">The share.</param>
 | 
	
		
			
				|  |  | -        /// <returns>NetworkShare.</returns>
 | 
	
		
			
				|  |  | -        private NetworkShare ToNetworkShare(Share share)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new NetworkShare
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                Name = share.NetName,
 | 
	
		
			
				|  |  | -                Path = share.Path,
 | 
	
		
			
				|  |  | -                Remark = share.Remark,
 | 
	
		
			
				|  |  | -                Server = share.Server,
 | 
	
		
			
				|  |  | -                ShareType = ToNetworkShareType(share.ShareType)
 | 
	
		
			
				|  |  | -            };
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// To the type of the network share.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="shareType">Type of the share.</param>
 | 
	
		
			
				|  |  | -        /// <returns>NetworkShareType.</returns>
 | 
	
		
			
				|  |  | -        /// <exception cref="System.ArgumentException">Unknown share type</exception>
 | 
	
		
			
				|  |  | -        private NetworkShareType ToNetworkShareType(ShareType shareType)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            if (shareType.HasFlag(ShareType.Special))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                return NetworkShareType.Special;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            if (shareType.HasFlag(ShareType.Device))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                return NetworkShareType.Device;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            if (shareType.HasFlag(ShareType.Disk))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                return NetworkShareType.Disk;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            if (shareType.HasFlag(ShareType.IPC))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                return NetworkShareType.Ipc;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            if (shareType.HasFlag(ShareType.Printer))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                return NetworkShareType.Printer;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            throw new ArgumentException("Unknown share type");
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Parses the specified endpointstring.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="endpointstring">The endpointstring.</param>
 | 
	
		
			
				|  |  | -        /// <returns>IPEndPoint.</returns>
 | 
	
		
			
				|  |  | -        public IPEndPoint Parse(string endpointstring)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Parse(endpointstring, -1);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Parses the specified endpointstring.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="endpointstring">The endpointstring.</param>
 | 
	
		
			
				|  |  | -        /// <param name="defaultport">The defaultport.</param>
 | 
	
		
			
				|  |  | -        /// <returns>IPEndPoint.</returns>
 | 
	
		
			
				|  |  | -        /// <exception cref="System.ArgumentException">Endpoint descriptor may not be empty.</exception>
 | 
	
		
			
				|  |  | -        /// <exception cref="System.FormatException"></exception>
 | 
	
		
			
				|  |  | -        private static IPEndPoint Parse(string endpointstring, int defaultport)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            if (string.IsNullOrEmpty(endpointstring)
 | 
	
		
			
				|  |  | -                || endpointstring.Trim().Length == 0)
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                throw new ArgumentException("Endpoint descriptor may not be empty.");
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (defaultport != -1 &&
 | 
	
		
			
				|  |  | -                (defaultport < IPEndPoint.MinPort
 | 
	
		
			
				|  |  | -                || defaultport > IPEndPoint.MaxPort))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                throw new ArgumentException(string.Format("Invalid default port '{0}'", defaultport));
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            string[] values = endpointstring.Split(new char[] { ':' });
 | 
	
		
			
				|  |  | -            IPAddress ipaddy;
 | 
	
		
			
				|  |  | -            int port = -1;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            //check if we have an IPv6 or ports
 | 
	
		
			
				|  |  | -            if (values.Length <= 2) // ipv4 or hostname
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                port = values.Length == 1 ? defaultport : GetPort(values[1]);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -                //try to use the address as IPv4, otherwise get hostname
 | 
	
		
			
				|  |  | -                if (!IPAddress.TryParse(values[0], out ipaddy))
 | 
	
		
			
				|  |  | -                    ipaddy = GetIPfromHost(values[0]);
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            else if (values.Length > 2) //ipv6
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                //could [a:b:c]:d
 | 
	
		
			
				|  |  | -                if (values[0].StartsWith("[") && values[values.Length - 2].EndsWith("]"))
 | 
	
		
			
				|  |  | -                {
 | 
	
		
			
				|  |  | -                    string ipaddressstring = string.Join(":", values.Take(values.Length - 1).ToArray());
 | 
	
		
			
				|  |  | -                    ipaddy = IPAddress.Parse(ipaddressstring);
 | 
	
		
			
				|  |  | -                    port = GetPort(values[values.Length - 1]);
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | -                else //[a:b:c] or a:b:c
 | 
	
		
			
				|  |  | -                {
 | 
	
		
			
				|  |  | -                    ipaddy = IPAddress.Parse(endpointstring);
 | 
	
		
			
				|  |  | -                    port = defaultport;
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            else
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                throw new FormatException(string.Format("Invalid endpoint ipaddress '{0}'", endpointstring));
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (port == -1)
 | 
	
		
			
				|  |  | -                throw new ArgumentException(string.Format("No port specified: '{0}'", endpointstring));
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            return new IPEndPoint(ipaddy, port);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        protected static readonly CultureInfo UsCulture = new CultureInfo("en-US");
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Gets the port.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="p">The p.</param>
 | 
	
		
			
				|  |  | -        /// <returns>System.Int32.</returns>
 | 
	
		
			
				|  |  | -        /// <exception cref="System.FormatException"></exception>
 | 
	
		
			
				|  |  | -        private static int GetPort(string p)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            int port;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (!int.TryParse(p, out port)
 | 
	
		
			
				|  |  | -             || port < IPEndPoint.MinPort
 | 
	
		
			
				|  |  | -             || port > IPEndPoint.MaxPort)
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                throw new FormatException(string.Format("Invalid end point port '{0}'", p));
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            return port;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Gets the I pfrom host.
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <param name="p">The p.</param>
 | 
	
		
			
				|  |  | -        /// <returns>IPAddress.</returns>
 | 
	
		
			
				|  |  | -        /// <exception cref="System.ArgumentException"></exception>
 | 
	
		
			
				|  |  | -        private static IPAddress GetIPfromHost(string p)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            var hosts = Dns.GetHostAddresses(p);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (hosts == null || hosts.Length == 0)
 | 
	
		
			
				|  |  | -                throw new ArgumentException(string.Format("Host not found: {0}", p));
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            return hosts[0];
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        /// <summary>
 | 
	
		
			
				|  |  | -        /// Uses the DllImport : NetServerEnum with all its required parameters
 | 
	
		
			
				|  |  | -        /// (see http://msdn.microsoft.com/library/default.asp?url=/library/en-us/netmgmt/netmgmt/netserverenum.asp
 | 
	
		
			
				|  |  | -        /// for full details or method signature) to retrieve a list of domain SV_TYPE_WORKSTATION
 | 
	
		
			
				|  |  | -        /// and SV_TYPE_SERVER PC's
 | 
	
		
			
				|  |  | -        /// </summary>
 | 
	
		
			
				|  |  | -        /// <returns>Arraylist that represents all the SV_TYPE_WORKSTATION and SV_TYPE_SERVER
 | 
	
		
			
				|  |  | -        /// PC's in the Domain</returns>
 | 
	
		
			
				|  |  | -        public IEnumerable<string> GetNetworkDevices()
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            //local fields
 | 
	
		
			
				|  |  | -            const int MAX_PREFERRED_LENGTH = -1;
 | 
	
		
			
				|  |  | -            var SV_TYPE_WORKSTATION = 1;
 | 
	
		
			
				|  |  | -            var SV_TYPE_SERVER = 2;
 | 
	
		
			
				|  |  | -            var buffer = IntPtr.Zero;
 | 
	
		
			
				|  |  | -            var tmpBuffer = IntPtr.Zero;
 | 
	
		
			
				|  |  | -            var entriesRead = 0;
 | 
	
		
			
				|  |  | -            var totalEntries = 0;
 | 
	
		
			
				|  |  | -            var resHandle = 0;
 | 
	
		
			
				|  |  | -            var sizeofINFO = Marshal.SizeOf(typeof(_SERVER_INFO_100));
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            try
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                //call the DllImport : NetServerEnum with all its required parameters
 | 
	
		
			
				|  |  | -                //see http://msdn.microsoft.com/library/default.asp?url=/library/en-us/netmgmt/netmgmt/netserverenum.asp
 | 
	
		
			
				|  |  | -                //for full details of method signature
 | 
	
		
			
				|  |  | -                var ret = NativeMethods.NetServerEnum(null, 100, ref buffer, MAX_PREFERRED_LENGTH, out entriesRead, out totalEntries, SV_TYPE_WORKSTATION | SV_TYPE_SERVER, null, out resHandle);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -                //if the returned with a NERR_Success (C++ term), =0 for C#
 | 
	
		
			
				|  |  | -                if (ret == 0)
 | 
	
		
			
				|  |  | -                {
 | 
	
		
			
				|  |  | -                    //loop through all SV_TYPE_WORKSTATION and SV_TYPE_SERVER PC's
 | 
	
		
			
				|  |  | -                    for (var i = 0; i < totalEntries; i++)
 | 
	
		
			
				|  |  | -                    {
 | 
	
		
			
				|  |  | -                        //get pointer to, Pointer to the buffer that received the data from
 | 
	
		
			
				|  |  | -                        //the call to NetServerEnum. Must ensure to use correct size of 
 | 
	
		
			
				|  |  | -                        //STRUCTURE to ensure correct location in memory is pointed to
 | 
	
		
			
				|  |  | -                        tmpBuffer = new IntPtr((int)buffer + (i * sizeofINFO));
 | 
	
		
			
				|  |  | -                        //Have now got a pointer to the list of SV_TYPE_WORKSTATION and 
 | 
	
		
			
				|  |  | -                        //SV_TYPE_SERVER PC's, which is unmanaged memory
 | 
	
		
			
				|  |  | -                        //Needs to Marshal data from an unmanaged block of memory to a 
 | 
	
		
			
				|  |  | -                        //managed object, again using STRUCTURE to ensure the correct data
 | 
	
		
			
				|  |  | -                        //is marshalled 
 | 
	
		
			
				|  |  | -                        var svrInfo = (_SERVER_INFO_100)Marshal.PtrToStructure(tmpBuffer, typeof(_SERVER_INFO_100));
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -                        //add the PC names to the ArrayList
 | 
	
		
			
				|  |  | -                        if (!string.IsNullOrEmpty(svrInfo.sv100_name))
 | 
	
		
			
				|  |  | -                        {
 | 
	
		
			
				|  |  | -                            yield return svrInfo.sv100_name;
 | 
	
		
			
				|  |  | -                        }
 | 
	
		
			
				|  |  | -                    }
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            finally
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                //The NetApiBufferFree function frees 
 | 
	
		
			
				|  |  | -                //the memory that the NetApiBufferAllocate function allocates
 | 
	
		
			
				|  |  | -                NativeMethods.NetApiBufferFree(buffer);
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -}
 |