// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
-#if NET_2_0 && SECURITY_DEP
-
using System.Collections;
using System.Collections.Generic;
namespace System.Net {
if (lp.Path.IndexOf ("//", StringComparison.Ordinal) != -1) // TODO: Code?
throw new HttpListenerException (400, "Invalid path.");
- // Always listens on all the interfaces, no matter the host name/ip used.
- EndPointListener epl = GetEPListener (IPAddress.Any, lp.Port, listener, lp.Secure);
+ // listens on all the interfaces if host name cannot be parsed by IPAddress.
+ EndPointListener epl = GetEPListener (lp.Host, lp.Port, listener, lp.Secure);
epl.AddPrefix (lp, listener);
}
- static EndPointListener GetEPListener (IPAddress addr, int port, HttpListener listener, bool secure)
+ static EndPointListener GetEPListener (string host, int port, HttpListener listener, bool secure)
{
+ IPAddress addr;
+ if (host == "*")
+ addr = IPAddress.Any;
+ else if (IPAddress.TryParse(host, out addr) == false){
+ try {
+ IPHostEntry iphost = Dns.GetHostByName(host);
+ if (iphost != null)
+ addr = iphost.AddressList[0];
+ else
+ addr = IPAddress.Any;
+ } catch {
+ addr = IPAddress.Any;
+ }
+ }
Hashtable p = null; // Dictionary<int, EndPointListener>
if (ip_to_endpoints.ContainsKey (addr)) {
p = (Hashtable) ip_to_endpoints [addr];
if (p.ContainsKey (port)) {
epl = (EndPointListener) p [port];
} else {
- epl = new EndPointListener (addr, port, secure);
+ epl = new EndPointListener (listener, addr, port, secure);
p [port] = epl;
}
if (lp.Path.IndexOf ("//", StringComparison.Ordinal) != -1)
return;
- EndPointListener epl = GetEPListener (IPAddress.Any, lp.Port, listener, lp.Secure);
+ EndPointListener epl = GetEPListener (lp.Host, lp.Port, listener, lp.Secure);
epl.RemovePrefix (lp, listener);
}
}
}
-#endif