2006-06-28 23:50:17 +04:00
#
2013-10-28 00:59:46 +04:00
# Copyright (C) 2006, 2013 Red Hat, Inc.
2006-06-28 23:50:17 +04:00
# Copyright (C) 2006 Daniel P. Berrange <berrange@redhat.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
2007-11-20 19:12:20 +03:00
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
# MA 02110-1301 USA.
2006-06-28 23:50:17 +04:00
#
2015-04-06 23:43:44 +03:00
import glob
2014-01-27 02:42:24 +04:00
import os
2011-04-18 20:39:53 +04:00
import logging
import socket
2013-04-16 21:38:19 +04:00
from gi . repository import Gio
2012-05-14 17:24:56 +04:00
from gi . repository import GObject
from gi . repository import Gtk
2011-04-18 20:39:53 +04:00
2014-09-13 00:10:45 +04:00
from . import uiutil
from . baseclass import vmmGObjectUI
2010-08-24 21:49:44 +04:00
2014-02-02 04:44:27 +04:00
( HV_QEMU ,
HV_XEN ,
HV_LXC ,
2014-04-10 21:54:37 +04:00
HV_QEMU_SESSION ,
HV_BHYVE ) = range ( 5 )
2007-07-12 03:52:53 +04:00
2014-02-02 04:44:27 +04:00
( CONN_SSH ,
CONN_TCP ,
CONN_TLS ) = range ( 3 )
2006-06-14 18:59:40 +04:00
2013-04-13 22:34:52 +04:00
2010-08-24 23:36:06 +04:00
def current_user ( ) :
try :
import getpass
return getpass . getuser ( )
except :
return " "
2013-04-13 22:34:52 +04:00
2010-08-24 23:36:06 +04:00
def default_conn_user ( conn ) :
if conn == CONN_SSH :
return " root "
return current_user ( )
2012-02-02 20:32:29 +04:00
2010-12-09 01:26:19 +03:00
class vmmConnect ( vmmGObjectUI ) :
2012-05-14 17:24:56 +04:00
__gsignals__ = {
" completed " : ( GObject . SignalFlags . RUN_FIRST , None , [ str , bool ] ) ,
" cancelled " : ( GObject . SignalFlags . RUN_FIRST , None , [ ] ) ,
}
2010-12-09 01:26:19 +03:00
def __init__ ( self ) :
2013-09-23 00:10:16 +04:00
vmmGObjectUI . __init__ ( self , " connect.ui " , " vmm-open-connection " )
2006-06-14 18:59:40 +04:00
2013-02-16 22:31:46 +04:00
self . builder . connect_signals ( {
2010-08-24 21:49:44 +04:00
" on_hypervisor_changed " : self . hypervisor_changed ,
2014-02-02 04:44:27 +04:00
" on_transport_changed " : self . transport_changed ,
2010-08-22 22:10:01 +04:00
" on_hostname_combo_changed " : self . hostname_combo_changed ,
2010-08-24 22:56:03 +04:00
" on_connect_remote_toggled " : self . connect_remote_toggled ,
2010-08-24 23:36:06 +04:00
" on_username_entry_changed " : self . username_changed ,
2013-09-23 00:29:58 +04:00
" on_hostname_changed " : self . hostname_changed ,
2010-08-22 22:10:01 +04:00
2006-06-14 22:36:26 +04:00
" on_cancel_clicked " : self . cancel ,
2011-07-23 00:43:26 +04:00
" on_connect_clicked " : self . open_conn ,
2006-06-14 22:36:26 +04:00
" on_vmm_open_connection_delete_event " : self . cancel ,
2012-11-08 17:15:02 +04:00
} )
2006-06-14 18:59:40 +04:00
2008-09-02 19:36:56 +04:00
self . browser = None
2011-07-23 23:13:08 +04:00
self . browser_sigs = [ ]
2008-09-02 19:36:56 +04:00
2009-03-09 23:21:21 +03:00
# Set this if we can't resolve 'hostname.local': means avahi
# prob isn't configured correctly, and we should strip .local
self . can_resolve_local = None
# Plain hostname resolve failed, means we should just use IP addr
self . can_resolve_hostname = None
2010-08-24 22:56:03 +04:00
self . set_initial_state ( )
2008-09-02 19:36:56 +04:00
try :
2013-04-16 21:38:19 +04:00
self . dbus = Gio . bus_get_sync ( Gio . BusType . SYSTEM , None )
self . avahiserver = Gio . DBusProxy . new_sync ( self . dbus , 0 , None ,
" org.freedesktop.Avahi " , " / " ,
" org.freedesktop.Avahi.Server " , None )
2015-04-20 19:32:33 +03:00
# Call any API, so we detect if avahi is even available or not
self . avahiserver . GetAPIVersion ( )
logging . debug ( " Connected to avahi " )
2008-09-02 19:36:56 +04:00
except Exception , e :
2015-04-20 19:32:33 +03:00
self . dbus = None
self . avahiserver = None
2012-01-17 07:04:40 +04:00
logging . debug ( " Couldn ' t contact avahi: %s " , str ( e ) )
2008-09-02 19:36:56 +04:00
self . reset_state ( )
2007-07-12 03:52:53 +04:00
2014-01-27 02:42:24 +04:00
@staticmethod
2015-04-06 23:43:44 +03:00
def default_uri ( ) :
2014-01-27 02:42:24 +04:00
if os . path . exists ( ' /var/lib/xen ' ) :
if ( os . path . exists ( ' /dev/xen/evtchn ' ) or
os . path . exists ( " /proc/xen " ) ) :
return ' xen:/// '
if ( os . path . exists ( " /usr/bin/qemu " ) or
os . path . exists ( " /usr/bin/qemu-kvm " ) or
os . path . exists ( " /usr/bin/kvm " ) or
2015-04-06 23:43:44 +03:00
os . path . exists ( " /usr/libexec/qemu-kvm " ) or
glob . glob ( " /usr/bin/qemu-system-* " ) ) :
return " qemu:///system "
2014-12-04 13:08:57 +03:00
if ( os . path . exists ( " /usr/lib/libvirt/libvirt_lxc " ) or
os . path . exists ( " /usr/lib64/libvirt/libvirt_lxc " ) ) :
return " lxc:/// "
2014-01-27 02:42:24 +04:00
return None
2010-11-29 22:06:43 +03:00
def cancel ( self , ignore1 = None , ignore2 = None ) :
2012-02-01 03:16:54 +04:00
logging . debug ( " Cancelling open connection " )
2006-06-14 22:36:26 +04:00
self . close ( )
2006-06-27 18:08:55 +04:00
self . emit ( " cancelled " )
2006-06-14 18:59:40 +04:00
return 1
2011-04-28 22:38:16 +04:00
def close ( self , ignore1 = None , ignore2 = None ) :
2012-02-01 03:16:54 +04:00
logging . debug ( " Closing open connection " )
2010-11-30 22:33:21 +03:00
self . topwin . hide ( )
2014-02-01 18:39:52 +04:00
if self . browser :
for obj , sig in self . browser_sigs :
obj . disconnect ( sig )
self . browser_sigs = [ ]
self . browser = None
2006-06-14 22:36:26 +04:00
2013-08-08 16:11:18 +04:00
def show ( self , parent , reset_state = True ) :
2012-02-01 03:16:54 +04:00
logging . debug ( " Showing open connection " )
2013-08-08 16:11:18 +04:00
if reset_state :
self . reset_state ( )
2011-04-14 16:47:42 +04:00
self . topwin . set_transient_for ( parent )
self . topwin . present ( )
2014-02-01 18:39:52 +04:00
self . start_browse ( )
2008-09-02 19:36:56 +04:00
2011-07-24 05:16:54 +04:00
def _cleanup ( self ) :
pass
2010-08-24 22:56:03 +04:00
def set_initial_state ( self ) :
2011-07-14 21:13:13 +04:00
self . widget ( " connect " ) . grab_default ( )
2010-08-24 22:56:03 +04:00
2014-02-02 04:44:27 +04:00
combo = self . widget ( " hypervisor " )
2015-04-06 23:29:28 +03:00
# [connection ID, label]
model = Gtk . ListStore ( int , str )
def _add_hv_row ( rowid , config_name , label ) :
if ( not self . config . default_hvs or
config_name in self . config . default_hvs ) :
model . append ( [ rowid , label ] )
_add_hv_row ( HV_QEMU , " qemu " , " QEMU/KVM " )
_add_hv_row ( HV_QEMU_SESSION , " qemu " , " QEMU/KVM user session " )
_add_hv_row ( HV_XEN , " xen " , " Xen " )
_add_hv_row ( HV_LXC , " lxc " , " LXC (Linux Containers) " )
_add_hv_row ( HV_BHYVE , " bhyve " , " Bhyve " )
2014-02-02 04:44:27 +04:00
combo . set_model ( model )
2015-04-10 20:04:02 +03:00
uiutil . init_combo_text_column ( combo , 1 )
2014-02-02 04:44:27 +04:00
combo = self . widget ( " transport " )
model = Gtk . ListStore ( str )
model . append ( [ " SSH " ] )
model . append ( [ " TCP (SASL, Kerberos) " ] )
model . append ( [ " SSL/TLS with certificates " ] )
combo . set_model ( model )
2015-04-10 20:04:02 +03:00
uiutil . init_combo_text_column ( combo , 0 )
2014-02-02 04:44:27 +04:00
2010-08-24 22:56:03 +04:00
# Hostname combo box entry
2012-05-14 17:24:56 +04:00
hostListModel = Gtk . ListStore ( str , str , str )
2011-07-14 21:13:13 +04:00
host = self . widget ( " hostname " )
2010-08-24 22:56:03 +04:00
host . set_model ( hostListModel )
2012-05-14 17:24:56 +04:00
host . set_entry_text_column ( 2 )
hostListModel . set_sort_column_id ( 2 , Gtk . SortType . ASCENDING )
2010-08-24 22:56:03 +04:00
2008-09-02 19:36:56 +04:00
def reset_state ( self ) :
2009-03-10 05:58:05 +03:00
self . set_default_hypervisor ( )
2014-02-02 04:44:27 +04:00
self . widget ( " transport " ) . set_active ( 0 )
2011-07-14 21:13:13 +04:00
self . widget ( " autoconnect " ) . set_sensitive ( True )
self . widget ( " autoconnect " ) . set_active ( True )
self . widget ( " hostname " ) . get_model ( ) . clear ( )
2012-05-14 17:24:56 +04:00
self . widget ( " hostname " ) . get_child ( ) . set_text ( " " )
2011-07-14 21:13:13 +04:00
self . widget ( " connect-remote " ) . set_active ( False )
self . widget ( " username-entry " ) . set_text ( " " )
self . connect_remote_toggled ( self . widget ( " connect-remote " ) )
2010-08-24 21:49:44 +04:00
self . populate_uri ( )
2006-06-14 18:59:40 +04:00
2010-08-24 22:56:03 +04:00
def is_remote ( self ) :
# Whether user is requesting a remote connection
2011-07-14 21:13:13 +04:00
return self . widget ( " connect-remote " ) . get_active ( )
2010-08-24 22:56:03 +04:00
2009-03-10 05:58:05 +03:00
def set_default_hypervisor ( self ) :
2015-04-06 23:43:44 +03:00
default = self . default_uri ( )
2011-07-19 04:27:20 +04:00
if not default or default . startswith ( " qemu " ) :
2015-05-20 01:13:33 +03:00
uiutil . set_list_selection ( self . widget ( " hypervisor " ) , HV_QEMU )
2009-03-10 05:58:05 +03:00
elif default . startswith ( " xen " ) :
2015-05-20 01:13:33 +03:00
uiutil . set_list_selection ( self . widget ( " hypervisor " ) , HV_XEN )
2009-03-10 05:58:05 +03:00
2013-04-12 16:26:21 +04:00
def add_service ( self , interface , protocol , name , typ , domain , flags ) :
2010-12-09 19:22:35 +03:00
ignore = flags
2008-09-02 19:36:56 +04:00
try :
# Async service resolving
2013-04-16 21:38:19 +04:00
res = self . avahiserver . ServiceResolverNew ( " (iisssiu) " ,
interface , protocol ,
name , typ , domain , - 1 , 0 )
resint = Gio . DBusProxy . new_sync ( self . dbus , 0 , None ,
" org.freedesktop.Avahi " , res ,
" org.freedesktop.Avahi.ServiceResolver " ,
None )
def cb ( proxy , sender , signal , args ) :
ignore = proxy
ignore = sender
if signal == " Found " :
self . add_conn_to_list ( * args )
sig = resint . connect ( " g-signal " , cb )
self . browser_sigs . append ( ( resint , sig ) )
2008-09-02 19:36:56 +04:00
except Exception , e :
logging . exception ( e )
2013-04-12 16:26:21 +04:00
def remove_service ( self , interface , protocol , name , typ , domain , flags ) :
2010-12-09 19:22:35 +03:00
ignore = domain
ignore = protocol
ignore = flags
ignore = interface
2013-04-12 16:26:21 +04:00
ignore = typ
2010-12-09 19:22:35 +03:00
2008-09-02 19:36:56 +04:00
try :
2011-07-14 21:13:13 +04:00
model = self . widget ( " hostname " ) . get_model ( )
2008-09-02 19:36:56 +04:00
name = str ( name )
for row in model :
if row [ 0 ] == name :
model . remove ( row . iter )
except Exception , e :
logging . exception ( e )
2013-04-12 16:26:21 +04:00
def add_conn_to_list ( self , interface , protocol , name , typ , domain ,
2008-09-02 19:36:56 +04:00
host , aprotocol , address , port , text , flags ) :
2010-12-09 19:22:35 +03:00
ignore = domain
ignore = protocol
ignore = flags
ignore = interface
2013-04-12 16:26:21 +04:00
ignore = typ
2010-12-09 19:22:35 +03:00
ignore = text
ignore = aprotocol
ignore = port
2008-09-02 19:36:56 +04:00
try :
2011-07-14 21:13:13 +04:00
model = self . widget ( " hostname " ) . get_model ( )
2008-09-02 19:36:56 +04:00
for row in model :
if row [ 2 ] == str ( name ) :
2009-03-09 23:21:21 +03:00
# Already present in list
2008-09-02 19:36:56 +04:00
return
2010-08-22 22:10:01 +04:00
2009-03-09 23:21:21 +03:00
host = self . sanitize_hostname ( str ( host ) )
2010-08-22 22:10:01 +04:00
model . append ( [ str ( address ) , str ( host ) , str ( name ) ] )
2008-09-02 19:36:56 +04:00
except Exception , e :
logging . exception ( e )
def start_browse ( self ) :
2013-04-16 21:38:19 +04:00
if self . browser or not self . avahiserver :
2008-09-02 19:36:56 +04:00
return
# Call method to create new browser, and get back an object path for it.
interface = - 1 # physical interface to use? -1 is unspec
protocol = 0 # 0 = IPv4, 1 = IPv6, -1 = Unspecified
2013-04-13 22:34:52 +04:00
service = ' _libvirt._tcp ' # Service name to poll for
2008-09-02 19:36:56 +04:00
flags = 0 # Extra option flags
domain = " " # Domain to browse in. NULL uses default
2013-04-16 21:38:19 +04:00
bpath = self . avahiserver . ServiceBrowserNew ( " (iissu) " ,
interface , protocol ,
service , domain , flags )
2008-09-02 19:36:56 +04:00
# Create browser interface for the new object
2013-04-16 21:38:19 +04:00
self . browser = Gio . DBusProxy . new_sync ( self . dbus , 0 , None ,
" org.freedesktop.Avahi " , bpath ,
" org.freedesktop.Avahi.ServiceBrowser " ,
None )
def cb ( proxy , sender , signal , args ) :
ignore = proxy
ignore = sender
if signal == " ItemNew " :
self . add_service ( * args )
elif signal == " ItemRemove " :
self . remove_service ( * args )
self . browser_sigs . append ( ( self . browser ,
self . browser . connect ( " g-signal " , cb ) ) )
2008-09-02 19:36:56 +04:00
2010-08-22 22:10:01 +04:00
def hostname_combo_changed ( self , src ) :
model = src . get_model ( )
2012-05-14 17:24:56 +04:00
txt = src . get_child ( ) . get_text ( )
2010-08-22 22:10:01 +04:00
row = None
for currow in model :
if currow [ 2 ] == txt :
row = currow
break
if not row :
2008-09-02 19:36:56 +04:00
return
2010-08-22 22:10:01 +04:00
ip = row [ 0 ]
host = row [ 1 ]
2008-09-02 19:36:56 +04:00
entry = host
if not entry :
entry = ip
2010-08-22 22:10:01 +04:00
2012-05-14 17:24:56 +04:00
self . widget ( " hostname " ) . get_child ( ) . set_text ( entry )
2006-06-14 18:59:40 +04:00
2010-12-09 19:22:35 +03:00
def hostname_changed ( self , src_ignore ) :
2010-08-24 21:49:44 +04:00
self . populate_uri ( )
2014-02-02 04:44:27 +04:00
def hypervisor_changed ( self , src ) :
2015-08-09 21:01:22 +03:00
ignore = src
2015-08-09 19:27:20 +03:00
hv = uiutil . get_list_selection ( self . widget ( " hypervisor " ) )
is_session = ( hv == HV_QEMU_SESSION )
2014-02-02 04:44:27 +04:00
uiutil . set_grid_row_visible (
self . widget ( " session-warning-box " ) , is_session )
uiutil . set_grid_row_visible (
self . widget ( " connect-remote " ) , not is_session )
uiutil . set_grid_row_visible (
self . widget ( " username-entry " ) , not is_session )
uiutil . set_grid_row_visible (
self . widget ( " hostname " ) , not is_session )
uiutil . set_grid_row_visible (
self . widget ( " transport " ) , not is_session )
if is_session :
self . widget ( " connect-remote " ) . set_active ( False )
2010-08-24 21:49:44 +04:00
self . populate_uri ( )
2010-12-09 19:22:35 +03:00
def username_changed ( self , src_ignore ) :
2010-08-24 23:36:06 +04:00
self . populate_uri ( )
2010-12-09 19:22:35 +03:00
def connect_remote_toggled ( self , src_ignore ) :
2010-08-24 22:56:03 +04:00
is_remote = self . is_remote ( )
2011-07-14 21:13:13 +04:00
self . widget ( " hostname " ) . set_sensitive ( is_remote )
2014-02-02 04:44:27 +04:00
self . widget ( " transport " ) . set_sensitive ( is_remote )
2011-07-14 21:13:13 +04:00
self . widget ( " autoconnect " ) . set_active ( not is_remote )
self . widget ( " username-entry " ) . set_sensitive ( is_remote )
2010-08-24 21:49:44 +04:00
2010-08-24 23:36:06 +04:00
self . populate_default_user ( )
2010-08-24 21:49:44 +04:00
self . populate_uri ( )
2014-02-02 04:44:27 +04:00
def transport_changed ( self , src_ignore ) :
2010-08-24 23:36:06 +04:00
self . populate_default_user ( )
2010-08-24 22:56:03 +04:00
self . populate_uri ( )
2010-08-24 21:49:44 +04:00
def populate_uri ( self ) :
uri = self . generate_uri ( )
2011-07-14 21:13:13 +04:00
self . widget ( " uri-entry " ) . set_text ( uri )
2010-08-24 21:49:44 +04:00
2010-08-24 23:36:06 +04:00
def populate_default_user ( self ) :
2014-02-02 04:44:27 +04:00
conn = self . widget ( " transport " ) . get_active ( )
2010-08-24 23:36:06 +04:00
default_user = default_conn_user ( conn )
2011-07-14 21:13:13 +04:00
self . widget ( " username-entry " ) . set_text ( default_user )
2010-08-24 23:36:06 +04:00
2010-08-24 21:49:44 +04:00
def generate_uri ( self ) :
2015-05-20 00:17:53 +03:00
hv = uiutil . get_list_selection ( self . widget ( " hypervisor " ) )
2014-02-02 04:44:27 +04:00
conn = self . widget ( " transport " ) . get_active ( )
2012-05-14 17:24:56 +04:00
host = self . widget ( " hostname " ) . get_child ( ) . get_text ( ) . strip ( )
2011-07-14 21:13:13 +04:00
user = self . widget ( " username-entry " ) . get_text ( )
2010-08-24 22:56:03 +04:00
is_remote = self . is_remote ( )
2006-06-14 18:59:40 +04:00
2010-08-24 21:49:44 +04:00
hvstr = " "
if hv == HV_XEN :
hvstr = " xen "
2014-02-17 19:22:24 +04:00
elif hv == HV_QEMU or hv == HV_QEMU_SESSION :
2010-08-24 21:49:44 +04:00
hvstr = " qemu "
2014-04-10 21:54:37 +04:00
elif hv == HV_BHYVE :
hvstr = " bhyve "
2011-06-22 01:19:55 +04:00
else :
hvstr = " lxc "
2010-08-24 21:49:44 +04:00
2010-08-24 23:36:06 +04:00
addrstr = " "
if user :
addrstr + = user + " @ "
addrstr + = host
2010-08-24 21:49:44 +04:00
hoststr = " "
2010-08-24 22:56:03 +04:00
if not is_remote :
2010-08-24 21:49:44 +04:00
hoststr = " :/// "
2010-08-24 23:36:06 +04:00
else :
if conn == CONN_TLS :
hoststr = " +tls:// "
if conn == CONN_SSH :
hoststr = " +ssh:// "
if conn == CONN_TCP :
hoststr = " +tcp:// "
hoststr + = addrstr + " / "
2010-08-24 21:49:44 +04:00
uri = hvstr + hoststr
2014-04-10 21:54:37 +04:00
if hv in ( HV_QEMU , HV_BHYVE ) :
2010-08-24 21:49:44 +04:00
uri + = " system "
2014-02-02 04:44:27 +04:00
elif hv == HV_QEMU_SESSION :
uri + = " session "
2010-08-24 21:49:44 +04:00
return uri
def validate ( self ) :
2010-08-24 22:56:03 +04:00
is_remote = self . is_remote ( )
2012-05-14 17:24:56 +04:00
host = self . widget ( " hostname " ) . get_child ( ) . get_text ( )
2010-08-24 21:49:44 +04:00
2010-08-24 22:56:03 +04:00
if is_remote and not host :
2010-08-24 21:49:44 +04:00
return self . err . val_err ( _ ( " A hostname is required for "
" remote connections. " ) )
return True
2011-07-23 00:43:26 +04:00
def open_conn ( self , ignore ) :
2010-08-24 21:49:44 +04:00
if not self . validate ( ) :
return
auto = False
2012-11-09 15:13:22 +04:00
if self . widget ( " autoconnect " ) . get_sensitive ( ) :
2011-07-14 21:13:13 +04:00
auto = self . widget ( " autoconnect " ) . get_active ( )
2010-08-24 21:49:44 +04:00
uri = self . generate_uri ( )
2012-01-17 07:04:40 +04:00
logging . debug ( " Generate URI= %s , auto= %s " , uri , auto )
2006-06-14 18:59:40 +04:00
self . close ( )
2011-07-15 04:52:40 +04:00
self . emit ( " completed " , uri , auto )
2006-06-14 22:36:26 +04:00
2008-09-02 19:36:56 +04:00
def sanitize_hostname ( self , host ) :
if host == " linux " or host == " localhost " :
host = " "
if host . startswith ( " linux- " ) :
tmphost = host [ 6 : ]
try :
2008-11-18 22:48:10 +03:00
long ( tmphost )
2008-09-02 19:36:56 +04:00
host = " "
except ValueError :
pass
2009-03-09 23:21:21 +03:00
if host :
host = self . check_resolve_host ( host )
return host
def check_resolve_host ( self , host ) :
# Try to resolve hostname
2013-04-17 17:09:53 +04:00
#
# Avahi always uses 'hostname.local', but for some reason
# fedora 12 out of the box can't resolve '.local' names
# Attempt to resolve the name. If it fails, remove .local
# if present, and try again
2009-03-09 23:21:21 +03:00
if host . endswith ( " .local " ) :
2012-11-08 17:15:02 +04:00
if self . can_resolve_local is False :
2009-03-09 23:21:21 +03:00
host = host [ : - 6 ]
2012-11-08 17:15:02 +04:00
elif self . can_resolve_local is None :
2009-03-09 23:21:21 +03:00
try :
socket . getaddrinfo ( host , None )
except :
logging . debug ( " Couldn ' t resolve host ' %s ' . Stripping "
2012-01-17 07:04:40 +04:00
" ' .local ' and retrying. " , host )
2009-03-09 23:21:21 +03:00
self . can_resolve_local = False
host = self . check_resolve_host ( host [ : - 6 ] )
else :
self . can_resolve_local = True
else :
2012-11-08 17:15:02 +04:00
if self . can_resolve_hostname is False :
2009-03-09 23:21:21 +03:00
host = " "
2012-11-08 17:15:02 +04:00
elif self . can_resolve_hostname is None :
2009-03-09 23:21:21 +03:00
try :
socket . getaddrinfo ( host , None )
except :
logging . debug ( " Couldn ' t resolve host ' %s ' . Disabling "
2012-01-17 07:04:40 +04:00
" host name resolution, only using IP addr " ,
2009-03-09 23:21:21 +03:00
host )
self . can_resolve_hostname = False
else :
self . can_resolve_hostname = True
2008-09-02 19:36:56 +04:00
return host