From 8d2ffbb17ce5dac6ae8abdf3c612e3348027090d 2013-01-25 19:45:32 From: W. Trevor King Date: 2013-01-25 19:45:32 Subject: [PATCH] utils.localinterfaces: Add PUBLIC_IPS to consolidate socket logic Consolidating IP detection in this module will let us remove socket.gethostbyname_ex calls from other modules and ensure that everyone agrees on what our public IPs should be. --- diff --git a/IPython/utils/localinterfaces.py b/IPython/utils/localinterfaces.py index 663cebd..d033c41 100644 --- a/IPython/utils/localinterfaces.py +++ b/IPython/utils/localinterfaces.py @@ -5,6 +5,9 @@ LOCALHOST : The loopback interface, or the first interface that points to this machine. It will *almost* always be '127.0.0.1' LOCAL_IPS : A list of IP addresses, loopback first, that point to this machine. + +PUBLIC_IPS : A list of public IP addresses that point to this machine. + Use these to tell remote clients where to find you. """ #----------------------------------------------------------------------------- # Copyright (C) 2010-2011 The IPython Development Team @@ -31,10 +34,14 @@ try: except socket.gaierror: pass +PUBLIC_IPS = [] try: - LOCAL_IPS.extend(socket.gethostbyname_ex(socket.gethostname())[2]) + PUBLIC_IPS = socket.gethostbyname_ex(socket.gethostname())[2] except socket.gaierror: pass +else: + PUBLIC_IPS = uniq_stable(PUBLIC_IPS) + LOCAL_IPS.extend(PUBLIC_IPS) # include all-interface aliases: 0.0.0.0 and '' LOCAL_IPS.extend(['0.0.0.0', ''])