CP-9365: XenCenter work for HVM linux support

-changes following the code review

Signed-off-by: Gabor Apati-Nagy <gabor.apati-nagy@citrix.com>
This commit is contained in:
Gabor Apati-Nagy 2014-08-22 17:36:41 +01:00
parent c458d16f7f
commit c928fd71ec
2 changed files with 20 additions and 13 deletions

View File

@ -60,6 +60,7 @@ namespace XenAdmin.ConsoleView
private readonly VNCView parentVNCView;
private readonly VM source;
private readonly Host targetHost;
private VM_guest_metrics guestMetrics = null;
private Form fullscreenForm = null;
private Form fullscreenHint = null;
private Size LastDesktopSize;
@ -75,6 +76,8 @@ namespace XenAdmin.ConsoleView
internal readonly ConsoleKeyHandler KeyHandler = new ConsoleKeyHandler();
private bool hasRDP { get { return source != null ? source.HasRDP : false; } }
public VNCTabView(VNCView parent, VM source, string elevatedUsername, string elevatedPassword)
{
Program.AssertOnEventThread();
@ -139,7 +142,7 @@ namespace XenAdmin.ConsoleView
this.vncScreen = new XSVNCScreen(source, new EventHandler(RDPorVNCResizeHandler), this, elevatedUsername, elevatedPassword);
ShowGpuWarningIfRequired();
if (source.is_control_domain || source.IsHVM && !source.HasRDP) //Linux HVM guests should only have one console: the console switch button vanishes altogether.
if (source.is_control_domain || source.IsHVM && !hasRDP) //Linux HVM guests should only have one console: the console switch button vanishes altogether.
{
toggleConsoleButton.Visible = false;
}
@ -470,12 +473,14 @@ namespace XenAdmin.ConsoleView
}
else if (e.PropertyName == "guest_metrics")
{
var guestMetrics = source.Connection.Resolve(source.guest_metrics);
if (guestMetrics != null)
{
guestMetrics.PropertyChanged -= guestMetrics_PropertyChanged;
guestMetrics.PropertyChanged += guestMetrics_PropertyChanged;
}
var newGuestMetrics = source.Connection.Resolve(source.guest_metrics);
//unsubscribing from the previous instance's event
if (this.guestMetrics != null)
this.guestMetrics.PropertyChanged -= guestMetrics_PropertyChanged;
this.guestMetrics = newGuestMetrics;
guestMetrics.PropertyChanged += guestMetrics_PropertyChanged;
EnableRDPIfCapable();
}
@ -498,7 +503,7 @@ namespace XenAdmin.ConsoleView
private void EnableRDPIfCapable()
{
if (!toggleConsoleButton.Visible && source.HasRDP)
if (!toggleConsoleButton.Visible && hasRDP)
{
// The toogle button is not visible now, because RDP had not been enabled on the VM when we started the console.
// However, the current guest_metrics indicates that RDP is now supported (HasRDP==true). (eg. XenTools has been installed in the meantime.)

View File

@ -118,6 +118,8 @@ namespace XenAdmin.ConsoleView
[DefaultValue(false)]
public bool UserWantsToSwitchProtocol { get; set; }
private bool hasRDP { get { return Source != null ? Source.HasRDP : false; } }
/// <summary>
/// Whether we have tried to login without providing a password (covers the case where the user
/// has configured VNC not to require a login password). If no password is saved, passwordless
@ -285,7 +287,7 @@ namespace XenAdmin.ConsoleView
private void PollRDPPort(Object Sender)
{
if (sourceVM.HasRDP && !Properties.Settings.Default.EnableRDPPolling)
if (hasRDP && !Properties.Settings.Default.EnableRDPPolling)
{
if (connectionPoller != null)
connectionPoller.Change(Timeout.Infinite, Timeout.Infinite);
@ -536,7 +538,7 @@ namespace XenAdmin.ConsoleView
if (RemoteConsole != null && RemoteConsole.ConsoleControl != null)
{
RemoteConsole.KeyHandler = this.KeyHandler;
RemoteConsole.SendScanCodes = sourceVM.HasRDP;
RemoteConsole.SendScanCodes = hasRDP;
RemoteConsole.Scaling = Scaling;
RemoteConsole.DisplayBorder = this.displayFocusRectangle;
SetKeyboardAndMouseCapture(autoCaptureKeyboardAndMouse);
@ -689,11 +691,11 @@ namespace XenAdmin.ConsoleView
//Start the polling again
if (Source != null && !Source.is_control_domain)
{
if (!sourceVM.IsHVM)
if (!Source.IsHVM)
{
connectionPoller = new Timer(PollVNCPort, null, RETRY_SLEEP_TIME, RDP_POLL_INTERVAL);
}
else if (sourceVM.HasRDP)
else if (hasRDP)
{
connectionPoller = new Timer(PollRDPPort, null, RETRY_SLEEP_TIME, RDP_POLL_INTERVAL);
}
@ -1007,7 +1009,7 @@ namespace XenAdmin.ConsoleView
}
else
{
v.SendScanCodes = UseSource && sourceVM.HasRDP;
v.SendScanCodes = UseSource && hasRDP;
v.SourceVM = sourceVM;
v.Console = console;
v.connect(stream, this.vncPassword);