xenadmin/XenAdmin/Diagnostics/Problems/Problem.cs
Mihaela Stoica 8c93206ce5 CP-19218: Add restart warnings to the Precheck Page when installing hotfixes
-  If reboot is needed, display this as an info, not a warning

Signed-off-by: Mihaela Stoica <mihaela.stoica@citrix.com>
2016-10-20 13:09:48 +01:00

140 lines
4.2 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 System.Drawing;
using XenAdmin.Actions;
using XenAdmin.Diagnostics.Checks;
namespace XenAdmin.Diagnostics.Problems
{
public abstract class Problem : IComparable<Problem>, IDisposable
{
private AsyncAction solutionAction;
private readonly Check _check;
public virtual bool IsFixable
{
get { return true; }
}
private void SolutionAction_Completed(ActionBase sender)
{
SolutionActionCompleted = true;
}
private void RegisterSolutionActionEvent()
{
if (solutionAction != null)
solutionAction.Completed += SolutionAction_Completed;
}
private void DeregisterSolutionActionEvent()
{
if (solutionAction != null)
solutionAction.Completed -= SolutionAction_Completed;
}
protected Problem(Check check)
{
if (check == null)
throw new ArgumentNullException();
_check = check;
}
public abstract string Title { get; }
public abstract string Description { get; }
public bool SolutionActionCompleted { get; private set; }
protected virtual AsyncAction CreateAction(out bool cancelled)
{
cancelled = false;
return null;
}
public AsyncAction SolveImmediately(out bool cancelled)
{
DeregisterSolutionActionEvent();
solutionAction = CreateAction(out cancelled);
SolutionActionCompleted = false;
RegisterSolutionActionEvent();
return solutionAction;
}
public abstract string HelpMessage { get; }
public Check Check
{
get { return _check; }
}
public virtual AsyncAction UnwindChanges()
{
return null;
}
public int CompareTo(Problem other)
{
if (!Description.Equals(other.Description))
return Description.CompareTo(other.Description);
return Title.CompareTo(other.Title);
}
public override bool Equals(object obj)
{
Problem problem = obj as Problem;
if (problem != null)
return this.CompareTo(problem) == 0;
return false;
}
public override int GetHashCode()
{
return _check.GetHashCode();
}
public virtual Image Image
{
get { return Images.GetImage16For(Icons.Error); }
}
#region IDisposable Members
public void Dispose()
{
DeregisterSolutionActionEvent();
}
#endregion
}
}