xenadmin/XenModel/Actions/VM/UpgradeVmInsertIsoAction.cs
Gabor Apati-Nagy 7b7bcb0aa5 CP-14379, CP-14461, CP-14462, CP-14463, CP-14464, CP-14465, CP-14467:
Implementing Upgrading VMs to Windows Update

New screen features:
-Create skeleton of the Upgrade VM dialog
-Implement a Go To Console link (just a link that opens a vm console)
-Implement logic to show the right status for a VM (includes rules to
get the states). Includes updating the dialog whenever the status changes.
-Add status texts to Messages, proper text on the UI
-Add stub methods to VM class in XenAPI-Extensions to r/w states from
Guest Agent
-UI: Implement rules what vms to display, checkbox rules, read only vms,
and when to enable the Upgrade button
-Implement Upgrade button (writes state for GA, mounts ISO) + maximum
parallel executions/actions

Signed-off-by: Gabor Apati-Nagy <gabor.apati-nagy@citrix.com>
2015-10-16 12:47:00 +01:00

156 lines
5.8 KiB
C#

/* Copyright (c) Citrix Systems Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms,
* with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above
* copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
using System;
using XenAPI;
using System.Linq;
namespace XenAdmin.Actions
{
public class UpgradeVmInsertIsoAction : AsyncAction
{
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
private readonly bool _searchHiddenIsOs;
// The 'well known' name of the ISO containing our PV tools.
public const string ISOName = "xs-tools.iso";
public UpgradeVmInsertIsoAction(VM vm, bool searchHiddenISOs)
: base(vm.Connection, string.Format(Messages.UPGRADEVM_ISO_STARTING, vm.Name))
{
VM = vm;
_searchHiddenIsOs = searchHiddenISOs;
#region RBAC Dependencies
foreach (SR sr in VM.Connection.Cache.SRs)
{
if (sr.IsToolsSR && sr.IsBroken())
{
ApiMethodsToRoleCheck.Add("pbd.plug");
ApiMethodsToRoleCheck.Add("pbd.create");
break;
}
}
ApiMethodsToRoleCheck.Add("vbd.eject");
ApiMethodsToRoleCheck.Add("vbd.insert");
ApiMethodsToRoleCheck.AddRange(Role.CommonSessionApiList);
#endregion
}
protected override void Run()
{
// check the xstools sr is present, if not try and repair it
foreach(SR sr in VM.Connection.Cache.SRs)
{
if (sr.IsToolsSR && sr.IsBroken())
{
try
{
SrRepairAction action = new SrRepairAction(sr.Connection, sr,false);
action.RunExternal(Session);
}
catch (Failure)
{
throw;
}
}
}
// Check that the VM has a cd-rom...
XenAPI.VBD cdrom = VM.FindVMCDROM();
if (cdrom == null)
{
Description = Messages.UPGRADEVM_COULDNOTFIND_CD;
return;
}
// Find the tools ISO...
XenAPI.VDI winIso = findWinISO(_searchHiddenIsOs);
if (winIso == null)
{
// Could not find the windows PV drivers ISO.
Description = Messages.UPGRADEVM_COULDNOTFIND_ISO;
return;
}
Description = Messages.UPGRADEVM_ISO_STARTING;
// Eject anything that's currently in the cd-rom...
if (!cdrom.empty)
{
XenAPI.VBD.eject(Session, cdrom.opaque_ref);
}
// Insert the ISO...
XenAPI.VBD.insert(Session, cdrom.opaque_ref, winIso.opaque_ref);
//Setting Upgrading persisted status on the VM
VM.ClientToGuestValue = VM.ClientToGuestMessage.INITIALIZING;
// TODO this (sleep and setting go to console) is here for now (setting go to console, but this will not be needed later
//
// waiting for the installer's message
System.Threading.Thread.Sleep(15000);
if (! new VM.GuestToClientMessage[] {VM.GuestToClientMessage.DONE, VM.GuestToClientMessage.ERROR, VM.GuestToClientMessage.RUNNING, VM.GuestToClientMessage.STARTED }
.Contains(VM.GuestToClientValue))
{
if (VM.ClientToGuestValue == XenAPI.VM.ClientToGuestMessage.INITIALIZING)
VM.ClientToGuestValue = XenAPI.VM.ClientToGuestMessage.GOTOCONSOLE;
}
Description = Messages.UPGRADEVM_ISO_DONE;
}
// Find the windows ISO disc by scanning the SRs - will return
// null if the disc could not be found...
private XenAPI.VDI findWinISO(bool searchHiddenISOs)
{
foreach (SR sr in Connection.Cache.SRs)
{
if (XenAPI.SR.SRTypes.iso.ToString() == sr.content_type)
{
foreach (VDI vdi in Connection.ResolveAllShownXenModelObjects(sr.VDIs, searchHiddenISOs))
{
if (ISOName.Equals(vdi.name_label))
{
return vdi;
}
}
}
}
return null;
}
}
}