2018-03-06 16:12:04 +01:00
|
|
|
|
/* 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.Collections.Generic;
|
2018-04-09 15:28:13 +02:00
|
|
|
|
using System.Text;
|
2018-03-06 16:12:04 +01:00
|
|
|
|
using XenAdmin.Core;
|
|
|
|
|
using XenAPI;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace XenAdmin.Wizards.PatchingWizard.PlanActions
|
|
|
|
|
{
|
|
|
|
|
public class RestartHostPlanAction : RebootPlanAction
|
|
|
|
|
{
|
|
|
|
|
private readonly List<XenRef<VM>> _vms;
|
2018-06-22 15:04:30 +02:00
|
|
|
|
public bool EnableOnly { get; set; }
|
2018-03-06 16:12:04 +01:00
|
|
|
|
private readonly bool _restartAgentFallback;
|
|
|
|
|
|
2018-03-07 18:50:51 +01:00
|
|
|
|
public RestartHostPlanAction(Host host, List<XenRef<VM>> vms, bool enableOnly = false, bool restartAgentFallback = false)
|
2018-03-06 16:12:04 +01:00
|
|
|
|
: base(host, string.Empty)
|
|
|
|
|
{
|
|
|
|
|
_vms = vms;
|
2018-06-22 15:04:30 +02:00
|
|
|
|
EnableOnly = enableOnly;
|
2018-03-06 16:12:04 +01:00
|
|
|
|
_restartAgentFallback = restartAgentFallback;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override void RunWithSession(ref Session session)
|
|
|
|
|
{
|
|
|
|
|
var hostObj = GetResolvedHost();
|
|
|
|
|
|
|
|
|
|
if (Helpers.ElyOrGreater(hostObj))
|
|
|
|
|
{
|
|
|
|
|
log.DebugFormat("Checking host.patches_requiring_reboot now on '{0}'.", hostObj);
|
|
|
|
|
|
|
|
|
|
if (hostObj.updates_requiring_reboot.Count > 0)
|
|
|
|
|
{
|
|
|
|
|
log.DebugFormat("Found {0} patches requiring reboot (live patching failed)."
|
|
|
|
|
+ "Initiating evacuate-reboot-bringbabiesback process.",
|
|
|
|
|
hostObj.updates_requiring_reboot.Count);
|
|
|
|
|
}
|
|
|
|
|
else if (_restartAgentFallback)
|
|
|
|
|
{
|
|
|
|
|
log.Debug("Live patching succeeded. Restarting agent.");
|
2018-04-09 15:28:13 +02:00
|
|
|
|
Visible = true;
|
|
|
|
|
Title = ProgressDescription = string.Format(Messages.UPDATES_WIZARD_RESTARTING_AGENT, hostObj.Name());
|
2018-03-06 16:12:04 +01:00
|
|
|
|
WaitForReboot(ref session, Host.AgentStartTime, s => Host.async_restart_agent(s, HostXenRef.opaque_ref));
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
log.Debug("Did not find patches requiring reboot (live patching succeeded)."
|
|
|
|
|
+ " Skipping scheduled restart.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-06-22 15:04:30 +02:00
|
|
|
|
|
2018-04-09 15:28:13 +02:00
|
|
|
|
Visible = true;
|
|
|
|
|
var sb = new StringBuilder();
|
2018-06-22 15:04:30 +02:00
|
|
|
|
|
|
|
|
|
var vms = hostObj.GetRunningVMs();
|
|
|
|
|
if (vms.Count > 0)
|
|
|
|
|
{
|
|
|
|
|
sb.Append(string.Format(Messages.PLANACTION_VMS_MIGRATING, hostObj.Name()));
|
|
|
|
|
ProgressDescription = sb.ToString();
|
|
|
|
|
EvacuateHost(ref session);
|
|
|
|
|
sb.AppendLine(Messages.DONE);
|
|
|
|
|
}
|
2018-04-09 15:28:13 +02:00
|
|
|
|
|
2018-06-22 15:04:30 +02:00
|
|
|
|
sb.AppendIndented(string.Format(Messages.UPDATES_WIZARD_REBOOTING, hostObj.Name()), sb.Length > 0 ? 2 : 0);
|
2018-04-09 15:28:13 +02:00
|
|
|
|
ProgressDescription = sb.ToString();
|
2018-03-06 16:12:04 +01:00
|
|
|
|
RebootHost(ref session);
|
2018-04-09 15:28:13 +02:00
|
|
|
|
sb.AppendLine(Messages.DONE);
|
|
|
|
|
|
2018-06-22 15:04:30 +02:00
|
|
|
|
sb.AppendIndented(string.Format(Messages.UPDATES_WIZARD_EXITING_MAINTENANCE_MODE, hostObj.Name()));
|
|
|
|
|
ProgressDescription = sb.ToString();
|
|
|
|
|
BringBabiesBack(ref session, _vms, EnableOnly);
|
2018-03-06 16:12:04 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|