diff --git a/WebsitePanel.Installer/Sources/Setup.WIXInstaller/Product.wxs b/WebsitePanel.Installer/Sources/Setup.WIXInstaller/Product.wxs
index c22fd509..273fbfaf 100644
--- a/WebsitePanel.Installer/Sources/Setup.WIXInstaller/Product.wxs
+++ b/WebsitePanel.Installer/Sources/Setup.WIXInstaller/Product.wxs
@@ -331,11 +331,14 @@
1
1
- &ServerFeature=3
- &EnterpriseServerFeature=3
- &PortalFeature=3
- &SchedulerServiceFeature=3
- &WDPortalFeature=3
+
+
+
+
+
+
+
+
1
1
@@ -357,7 +360,10 @@
""]]>
"" AND DSOP_UPN = ""]]>
- 1
+
+ 1
+
+
&EnterpriseServerFeature=3 AND VALIDATE_OK = "1"
&PortalFeature=3 AND VALIDATE_OK = "1"
&SchedulerServiceFeature=3 AND VALIDATE_OK = "1"
@@ -389,7 +395,11 @@
""]]>
"" AND DSOP_UPN = ""]]>
- 1
+
+
+ 1
+
+
VALIDATE_OK="0"
1
@@ -437,16 +447,22 @@
""]]>
"" AND DSOP_UPN = ""]]>
- 1
+
+
+
+ 1
1
1
-
-
-
- 3]]>
- 3 AND &PortalFeature<>3]]>
+
+
+
+
+
+
+ 3 AND COMPFOUND_ESERVER=0]]>
+ 3 AND &PortalFeature<>3 AND COMPFOUND_SERVER=0]]>
1
1
@@ -540,9 +556,15 @@
-
+
+
+
+
+
+
+
@@ -589,6 +611,13 @@
+
+
+
+
+
+
+
WSP_BASE
@@ -611,7 +640,15 @@
-
+
+
+
+
+
+
+
+
+
1
@@ -634,7 +671,7 @@
- (NOT Installed OR NOT WIX_UPGRADE_DETECTED) AND NOT(DB_AUTH = "Windows Authentication")
+ (NOT Installed AND NOT WIX_UPGRADE_DETECTED) AND NOT(DB_AUTH = "Windows Authentication")
- (NOT Installed OR NOT WIX_UPGRADE_DETECTED) AND (DB_AUTH = "Windows Authentication")
+ (NOT Installed AND NOT WIX_UPGRADE_DETECTED) AND (DB_AUTH = "Windows Authentication")
/// LoadSetupVariablesFromParameters.
@@ -393,6 +397,9 @@ namespace WebsitePanel.Setup.Internal
case ActionTypes.ConfigureSecureSessionModuleInWebConfig:
ConfigureSecureSessionModuleInWebConfig();
break;
+ case ActionTypes.RestoreConfig:
+ RestoreXmlConfigs(Execute.SetupVariables);
+ break;
}
}
catch (Exception ex)
@@ -402,7 +409,6 @@ namespace WebsitePanel.Setup.Internal
}
}
}
-
protected virtual List GetActions(string ComponentID)
{
return new List();
@@ -843,7 +849,7 @@ namespace WebsitePanel.Setup.Internal
return;
}
// Load web.config
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
// add node:
@@ -993,7 +999,7 @@ namespace WebsitePanel.Setup.Internal
return;
}
// Load web.config
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
// do Windows 2008 platform-specific changes
bool iis7 = (Context.IISVersion.Major >= 7);
@@ -1229,7 +1235,7 @@ namespace WebsitePanel.Setup.Internal
private string GetConnectionString(string webConfigPath)
{
string ret = null;
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
//connection string
string xPath = "configuration/connectionStrings/add[@name=\"EnterpriseServer\"]";
@@ -1244,7 +1250,7 @@ namespace WebsitePanel.Setup.Internal
private string GetCryptoKey(string webConfigPath)
{
string ret = null;
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
//crypto key
string xPath = "configuration/appSettings/add[@key=\"WebsitePanel.CryptoKey\"]";
@@ -1258,7 +1264,7 @@ namespace WebsitePanel.Setup.Internal
private bool IsEncryptionEnabled(string webConfigPath)
{
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
//encryption enabled
string xPath = "configuration/appSettings/add[@key=\"WebsitePanel.EncryptionEnabled\"]";
@@ -2316,7 +2322,7 @@ namespace WebsitePanel.Setup.Internal
}
Log.WriteStart("Updating config.xml file");
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(path);
XmlNode serversNode = doc.SelectSingleNode("//myLittleAdmin/sqlservers");
@@ -2429,7 +2435,7 @@ namespace WebsitePanel.Setup.Internal
return;
}
// Load web.config
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
// Tighten WSE security on local machine
@@ -2513,7 +2519,7 @@ namespace WebsitePanel.Setup.Internal
}
Log.WriteStart("Loading portal settings");
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(path);
string xPath = "configuration/connectionStrings/add[@name=\"SiteSqlServer\"]";
@@ -2605,7 +2611,7 @@ namespace WebsitePanel.Setup.Internal
}
Log.WriteStart("Updating site settings");
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(path);
XmlElement urlNode = doc.SelectSingleNode("SiteSettings/EnterpriseServer") as XmlElement;
@@ -3178,7 +3184,7 @@ namespace WebsitePanel.Setup.Internal
}
Log.WriteStart("Updating configuration file (server password)");
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(path);
XmlElement passwordNode = doc.SelectSingleNode("//websitepanel.server/security/password") as XmlElement;
@@ -3221,7 +3227,7 @@ namespace WebsitePanel.Setup.Internal
}
Log.WriteStart("Updating configuration file (service settings)");
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(path);
XmlElement ipNode = doc.SelectSingleNode("//configuration/appSettings/add[@key='WebsitePanel.HostIP']") as XmlElement;
@@ -3881,7 +3887,7 @@ namespace WebsitePanel.Setup.Internal
return;
}
// Load web.config
- XmlDocument doc = new XmlDocument();
+ var doc = new XmlDocument();
doc.Load(webConfigPath);
// replace existing node:
@@ -3915,8 +3921,63 @@ namespace WebsitePanel.Setup.Internal
}
#endregion
#endregion
+ private void RestoreXmlConfigs(SetupVariables Ctx)
+ {
+ try
+ {
+ Log.WriteStart("RestoreXmlConfigs");
+ var Backup = BackupRestore.Find(Ctx.InstallerFolder, "WebsitePanel", Ctx.ComponentName);
+ switch(Ctx.ComponentCode)
+ {
+ case "server":
+ {
+ Backup.XmlFiles.Add("Web.config");
+ }
+ break;
+ case "enterpriseserver":
+ {
+ Backup.XmlFiles.Add("Web.config");
+ }
+ break;
+ case "portal":
+ {
+ Backup.XmlFiles.Add("Web.config");
+ Backup.XmlFiles.Add(@"App_Data\Countries.config");
+ Backup.XmlFiles.Add(@"App_Data\CountryStates.config");
+ Backup.XmlFiles.Add(@"App_Data\Ecommerce_Modules.config");
+ Backup.XmlFiles.Add(@"App_Data\Ecommerce_Pages.config");
+ Backup.XmlFiles.Add(@"App_Data\ESModule_ControlsHierarchy.config");
+ Backup.XmlFiles.Add(@"App_Data\ModulesData.config");
+ Backup.XmlFiles.Add(@"App_Data\SiteSettings.config");
+ Backup.XmlFiles.Add(@"App_Data\SupportedLocales.config");
+ Backup.XmlFiles.Add(@"App_Data\SupportedThemes.config");
+ Backup.XmlFiles.Add(@"App_Data\WebsitePanel_Modules.config");
+ Backup.XmlFiles.Add(@"App_Data\WebsitePanel_Pages.config");
+ }
+ break;
+ }
+ var MainCfg = Path.Combine(Ctx.InstallerFolder, BackupRestore.MainConfig);
+ var XCfg = new XmlDocument();
+ XCfg.Load(MainCfg);
+ if (XCfg.SelectSingleNode("//components").ChildNodes.Count == 0)
+ {
+ Log.WriteInfo("Restoring main config...");
+ XmlDocumentMerge.Process(Backup.BackupMainConfigFile, MainCfg);
+ Context.ComponentId = WiXSetup.GetComponentID(Ctx);
+ AppConfig.LoadConfiguration(new ExeConfigurationFileMap { ExeConfigFilename = MainCfg });
+ AppConfig.LoadComponentSettings(Ctx);
+ }
+ Log.WriteInfo(string.Format("Restoring xml config for component - {0}.", Ctx.ComponentFullName));
+ Backup.Restore();
+ Log.WriteEnd("RestoreXmlConfigs");
+ }
+ catch (Exception ex)
+ {
+ Log.WriteError("RestoreXmlConfigs", ex);
+ throw;
+ }
+ }
}
-
public class UninstallScript : SetupScript // UninstallPage
{
public UninstallScript(SetupVariables SessionVariables):base(SessionVariables)
@@ -4117,12 +4178,22 @@ namespace WebsitePanel.Setup.Internal
protected override List GetActions(string ComponentID)
{
var Scenario = base.GetActions(ComponentID);
- var Act = new InstallAction(ActionTypes.UpdateConfig);
- Act.Description = "Updating system configuration...";
- Scenario.Add(Act);
- Act = new InstallAction(ActionTypes.StartApplicationPool);
- Act.Description = "Starting IIS Application Pool...";
- Scenario.Add(Act);
+ Scenario.Add(new InstallAction(ActionTypes.RestoreConfig) { SetupVariables = Context, Description = "Restoring xml configuration files..." });
+ Scenario.Add(new InstallAction(ActionTypes.UpdateConfig) { Description = "Updating system configuration..." });
+ Scenario.Add(new InstallAction(ActionTypes.StartApplicationPool) { Description = "Starting IIS Application Pool..." });
+ return Scenario;
+ }
+ }
+ public class MaintenanceScript: ExpressScript
+ {
+ public MaintenanceScript(SetupVariables SessionVariables):base(SessionVariables)
+ {
+ Context.SetupAction = SetupActions.Setup;
+ }
+ protected override List GetActions(string ComponentID)
+ {
+ var Scenario = base.GetActions(ComponentID);
+ Scenario.Add(new InstallAction(ActionTypes.UpdateConfig) { Description = "Updating system configuration..." });
return Scenario;
}
}
@@ -4170,6 +4241,7 @@ namespace WebsitePanel.Setup.Internal
else if (ModeExtension == ModeExtension.Restore)
{
Context.ComponentId = GetComponentID(Context);
+ Context.UpdateVersion = Context.Release;
AppConfig.LoadComponentSettings(Context);
new RestoreScript(Context).Run();
}
@@ -4194,12 +4266,19 @@ namespace WebsitePanel.Setup.Internal
}
Script.Run();
}
+ protected override void Maintenance()
+ {
+ Context.ComponentId = GetComponentID(Context);
+ AppConfig.LoadComponentSettings(Context);
+ SetupScript Script = new MaintenanceScript(Context);
+ Script.Actions.Add(new InstallAction(ActionTypes.UpdateServerPassword) { Description = "Updating server password..." });
+ Script.Run();
+ }
}
-
public class EServerSetup : WiXSetup
{
- public EServerSetup(SetupVariables Ctx)
- : base(Ctx)
+ public EServerSetup(SetupVariables Ctx, ModeExtension Ext)
+ : base(Ctx, Ext)
{
}
@@ -4210,7 +4289,7 @@ namespace WebsitePanel.Setup.Internal
SetupVars.SetupAction = Action;
SetupVars.IISVersion = Global.IISVersion;
AppConfig.LoadConfiguration(new ExeConfigurationFileMap { ExeConfigFilename = GetFullConfigPath(SetupVars) });
- return new EServerSetup(SetupVars);
+ return new EServerSetup(SetupVars, GetModeExtension(Ctx));
}
protected override void Install()
{
@@ -4240,6 +4319,7 @@ namespace WebsitePanel.Setup.Internal
else if (ModeExtension == ModeExtension.Restore)
{
Context.ComponentId = GetComponentID(Context);
+ Context.UpdateVersion = Context.Release;
AppConfig.LoadComponentSettings(Context);
new RestoreScript(Context).Run();
}
@@ -4264,12 +4344,19 @@ namespace WebsitePanel.Setup.Internal
}
Script.Run();
}
+ protected override void Maintenance()
+ {
+ Context.ComponentId = GetComponentID(Context);
+ AppConfig.LoadComponentSettings(Context);
+ SetupScript Script = new MaintenanceScript(Context);
+ Script.Actions.Add(new InstallAction(ActionTypes.UpdateServerAdminPassword) { Description = "Updating serveradmin password..." });
+ Script.Run();
+ }
}
-
public class PortalSetup : WiXSetup
{
- public PortalSetup(SetupVariables Ctx)
- : base(Ctx)
+ public PortalSetup(SetupVariables Ctx, ModeExtension Ext)
+ : base(Ctx, Ext)
{
}
@@ -4280,7 +4367,7 @@ namespace WebsitePanel.Setup.Internal
SetupVars.SetupAction = Action;
SetupVars.IISVersion = Global.IISVersion;
AppConfig.LoadConfiguration(new ExeConfigurationFileMap { ExeConfigFilename = GetFullConfigPath(SetupVars) });
- return new PortalSetup(SetupVars);
+ return new PortalSetup(SetupVars, GetModeExtension(Ctx));
}
protected override void Install()
{
@@ -4306,17 +4393,11 @@ namespace WebsitePanel.Setup.Internal
}
if (WiXThrow)
InstallFailed();
-
- else if (ModeExtension == ModeExtension.Restore)
- {
- Context.ComponentId = GetComponentID(Context);
- AppConfig.LoadComponentSettings(Context);
- new RestoreScript(Context).Run();
- }
}
else if (ModeExtension == ModeExtension.Restore)
{
Context.ComponentId = GetComponentID(Context);
+ Context.UpdateVersion = Context.Release;
AppConfig.LoadComponentSettings(Context);
new RestoreScript(Context).Run();
}
@@ -4348,8 +4429,15 @@ namespace WebsitePanel.Setup.Internal
}
Script.Run();
}
+ protected override void Maintenance()
+ {
+ Context.ComponentId = GetComponentID(Context);
+ AppConfig.LoadComponentSettings(Context);
+ SetupScript Script = new MaintenanceScript(Context);
+ Script.Actions.Add(new InstallAction(ActionTypes.UpdateEnterpriseServerUrl) { Description = "Updating site settings..." });
+ Script.Run();
+ }
}
-
#region WiXActionManagers
public class WiXServerActionManager : BaseActionManager
{
diff --git a/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/BackupRestore.cs b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/BackupRestore.cs
new file mode 100644
index 00000000..5778175f
--- /dev/null
+++ b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/BackupRestore.cs
@@ -0,0 +1,122 @@
+using System;
+using System.Collections.Generic;
+using System.Globalization;
+using System.IO;
+using System.Linq;
+using System.Xml;
+using Ionic.Zip;
+
+namespace WebsitePanel.Setup.Internal
+{
+ class BackupRestore
+ {
+ struct DirectoryTag
+ {
+ public string Name;
+ public DateTime Date;
+ public Version Version;
+ }
+ public const string MainConfig = "WebsitePanel.config";
+ const string BackupDirectory = "Backup";
+ const string ConfigDirectory = "Config";
+ const string AppZip = @"App\app.zip";
+ const string DateFormat = "yyyy-MM-dd";
+ public BackupRestore()
+ {
+ XmlFiles = new List();
+ }
+ public static BackupRestore Find(string Root, string Product, string Id)
+ {
+ var Result = default(BackupRestore);
+ var Dir = Path.Combine(Root, BackupDirectory);
+ var FullId = GetFullId(Product, Id);
+ if (Directory.Exists(Dir))
+ {
+ var DirList = new List();
+ foreach (var DateItem in Directory.GetDirectories(Dir))
+ {
+ DateTime date;
+ var DateName = new DirectoryInfo(DateItem).Name;
+ if (DateTime.TryParseExact(DateName, DateFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out date))
+ {
+ foreach (var VersionItem in Directory.GetDirectories(DateItem))
+ {
+ var VersionName = new DirectoryInfo(VersionItem).Name;
+ if (VersionName.StartsWith(FullId, StringComparison.InvariantCultureIgnoreCase))
+ {
+ Version BckpVersion;
+ var StrVersion = VersionName.Substring(FullId.Length);
+ if (Version.TryParse(StrVersion, out BckpVersion))
+ {
+ DirList.Add(new DirectoryTag { Name = VersionItem, Date = date, Version = BckpVersion });
+ }
+ }
+ }
+ }
+ }
+ var ByVersion = from i in DirList where i.Version == (from v in DirList select v.Version).Max() select i;
+ var ByDate = from i in ByVersion where i.Date == (from v in ByVersion select v.Date).Max() select i;
+ var SrcTag = ByDate.First();
+ Result = new BackupRestore { Id = Id, Root = GetComponentRoot(SrcTag, Id), BackupFile = Path.Combine(SrcTag.Name, AppZip), BackupMainConfigFile = GetMainConfig(SrcTag) };
+ }
+ return Result;
+ }
+ private static string GetComponentRoot(DirectoryTag DirTag, string Id)
+ {
+ var Cfg = GetMainConfig(DirTag);
+ if (string.IsNullOrWhiteSpace(Cfg))
+ throw new Exception("Broken backup. Main config file not found.");
+ var XCfg = new XmlDocument();
+ XCfg.Load(Cfg);
+ var Component = XCfg.SelectSingleNode(string.Format("//component[.//add/@key='ComponentName' and .//add/@value='{0}']", Id));
+ var InstallFolder = Component.SelectSingleNode(".//add[@key='InstallFolder']");
+ return InstallFolder.Attributes["value"].Value;
+ }
+ private static string GetMainConfig(DirectoryTag DirTag)
+ {
+ return Path.Combine(DirTag.Name, ConfigDirectory, MainConfig);
+ }
+ private static string GetFullId(string Product, string Id)
+ {
+ return string.Format("{0} {1}", Product, Id);
+ }
+ public virtual void Restore()
+ {
+ using (var Bckp = new ZipFile(BackupFile))
+ {
+ foreach (var Xml in XmlFiles)
+ {
+ var SrcEntry = from Entry in Bckp.Entries where NormalizePath(Entry.FileName.ToLowerInvariant(), "/") == Xml.ToLowerInvariant() select Entry;
+ if (SrcEntry != null)
+ {
+ if (SrcEntry.LongCount() > 1)
+ throw new Exception(string.Format("Too many backup entries - {0}.", Xml));
+ var FileEntry = SrcEntry.FirstOrDefault();
+ if (FileEntry != null)
+ {
+ using (var InMem = new MemoryStream())
+ {
+ FileEntry.Extract(InMem);
+ InMem.Seek(0, SeekOrigin.Begin);
+ using (var OutFile = new FileStream(Path.Combine(Root, Xml), FileMode.Open, FileAccess.ReadWrite))
+ {
+ XmlDocumentMerge.Process(InMem, OutFile);
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ private string NormalizePath(string FilePath, string In)
+ {
+ return Path.Combine(FilePath.Split(new string[] { In }, StringSplitOptions.RemoveEmptyEntries));
+ }
+ public string Id { get; set; } // Component full name.
+ public string Comment { get; set; }
+ public string BackupFile { get; set; } // Should be zip archive.
+ public string BackupMainConfigFile { get; set; }
+ public IList XmlFiles { get; set; } // Xml files (configs) to merge and update.
+ public string Root { get; set; }
+ }
+}
diff --git a/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/XmlDocumentMerge.cs b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/XmlDocumentMerge.cs
new file mode 100644
index 00000000..4c4511c4
--- /dev/null
+++ b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/Internal/XmlDocumentMerge.cs
@@ -0,0 +1,139 @@
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Xml;
+using System.Xml.XPath;
+
+namespace WebsitePanel.Setup.Internal
+{
+ public static class XmlDocumentMerge
+ {
+ const string SuccessFormat = "Success: {0}.";
+ const string ErrorFormat = "Error: {0}.";
+ const string MergeCompleted = "XmlDocumentMerge completed";
+ static XmlDocumentMerge()
+ {
+ KeyAttributes = new List { "name", "id", "key" };
+ }
+ public static List KeyAttributes { get; set; }
+ public static string Process(string Src, string Dst, string SaveTo = "")
+ {
+ var Result = string.Empty;
+ if (!File.Exists(Src))
+ Result = string.Format(ErrorFormat, string.Format("source document [{0}] does not exists", Src));
+ else if (!File.Exists(Dst))
+ Result = string.Format(ErrorFormat, string.Format("destination document [{0}] does not exists", Dst));
+ else
+ {
+ try
+ {
+ var InStream = new FileStream(Src, FileMode.Open, FileAccess.Read);
+ var OutStream = new FileStream(Dst, FileMode.Open, FileAccess.ReadWrite);
+ Result = Process(InStream,
+ OutStream,
+ SaveTo);
+ InStream.Close();
+ OutStream.Flush();
+ OutStream.Close();
+ }
+ catch (Exception ex)
+ {
+ Result = string.Format(ErrorFormat, ex.ToString());
+ }
+ }
+ return Result;
+ }
+ public static string Process(Stream InSrc, Stream OutDst, string SaveTo = "")
+ {
+ var Result = string.Format(SuccessFormat, MergeCompleted);
+ try
+ {
+ var SrcDoc = new XmlDocument();
+ SrcDoc.Load(InSrc);
+ var DstDoc = new XmlDocument();
+ DstDoc.Load(OutDst);
+ var DstNavi = DstDoc.CreateNavigator();
+ var DstIterator = DstNavi.SelectChildren(XPathNodeType.All);
+ while (DstIterator.MoveNext())
+ Merge(DstIterator.Current.Clone(), SrcDoc, string.Empty);
+ if (string.IsNullOrWhiteSpace(SaveTo))
+ {
+ OutDst.SetLength(0);
+ DstDoc.Save(OutDst);
+ }
+ else
+ DstDoc.Save(SaveTo);
+ }
+ catch (Exception ex)
+ {
+ Result = string.Format(ErrorFormat, ex.ToString());
+ }
+ return Result;
+ }
+ private static string NodePath(string Parent, string Current)
+ {
+ var Result = string.Empty;
+ if (!string.IsNullOrWhiteSpace(Parent) && !string.IsNullOrWhiteSpace(Current))
+ Result = string.Format("{0}/{1}", Parent, Current);
+ else if (!string.IsNullOrWhiteSpace(Parent))
+ Result = Parent;
+ else if (!string.IsNullOrWhiteSpace(Current))
+ Result = Current;
+ return Result;
+ }
+ private static string NodeView(XPathNavigator Navi)
+ {
+ foreach (var Attr in KeyAttributes)
+ {
+ var Value = Navi.GetAttribute(Attr, string.Empty);
+ if (!string.IsNullOrWhiteSpace(Value))
+ return string.Format("{0}[@{1}='{2}']", Navi.Name, Attr, Value);
+ }
+ return Navi.Name;
+ }
+ private static void Merge(XPathNavigator DstNavi, XmlDocument SrcDoc, string Parent)
+ {
+ if (DstNavi.NodeType == XPathNodeType.Element)
+ {
+ var SrcElem = SrcDoc.SelectSingleNode(NodePath(Parent, NodeView(DstNavi)));
+ if (SrcElem != null)
+ {
+ if (DstNavi.MoveToFirstAttribute())
+ {
+ do
+ {
+ var SrcElemAttr = SrcElem.Attributes[DstNavi.LocalName];
+ if (SrcElemAttr != null)
+ DstNavi.SetValue(SrcElemAttr.Value);
+ }
+ while (DstNavi.MoveToNextAttribute());
+ DstNavi.MoveToParent();
+ }
+ }
+ }
+ else if (DstNavi.NodeType == XPathNodeType.Text)
+ {
+ var SrcElem = SrcDoc.SelectSingleNode(NodePath(Parent, NodeView(DstNavi)));
+ if (SrcElem != null)
+ DstNavi.SetValue(SrcElem.InnerText);
+ }
+ var Here = NodeView(DstNavi);
+ if (DstNavi.MoveToFirstChild())
+ {
+ do
+ {
+ Merge(DstNavi, SrcDoc, NodePath(Parent, Here));
+ }
+ while (DstNavi.MoveToNext());
+ DstNavi.MoveToParent();
+ }
+ else if (DstNavi.NodeType == XPathNodeType.Element)
+ {
+ var SrcElem = SrcDoc.SelectSingleNode(NodePath(Parent, Here));
+ if (SrcElem != null && !string.IsNullOrWhiteSpace(SrcElem.InnerXml))
+ foreach (XmlNode Child in SrcElem.ChildNodes)
+ DstNavi.AppendChild(Child.CloneNode(true).CreateNavigator());
+ }
+ }
+ }
+}
diff --git a/WebsitePanel.Installer/Sources/WebsitePanel.Setup/WebsitePanel.Setup.csproj b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/WebsitePanel.Setup.csproj
index 246d4850..864c3e5d 100644
--- a/WebsitePanel.Installer/Sources/WebsitePanel.Setup/WebsitePanel.Setup.csproj
+++ b/WebsitePanel.Installer/Sources/WebsitePanel.Setup/WebsitePanel.Setup.csproj
@@ -144,6 +144,8 @@
+
+
diff --git a/WebsitePanel.Installer/Sources/WebsitePanel.WIXInstaller/CustomAction.cs b/WebsitePanel.Installer/Sources/WebsitePanel.WIXInstaller/CustomAction.cs
index e14b3ce4..3bc32d46 100644
--- a/WebsitePanel.Installer/Sources/WebsitePanel.WIXInstaller/CustomAction.cs
+++ b/WebsitePanel.Installer/Sources/WebsitePanel.WIXInstaller/CustomAction.cs
@@ -54,6 +54,33 @@ namespace WebsitePanel.WIXInstaller
#region CustomActions
[CustomAction]
+ public static ActionResult MaintenanceServer(Session session)
+ {
+ var Result = ActionResult.Success;
+ Log.WriteStart("MaintenanceServer");
+ Result = ProcessInstall(session, WiXInstallType.MaintenanceServer);
+ Log.WriteEnd("MaintenanceServer");
+ return Result;
+ }
+ [CustomAction]
+ public static ActionResult MaintenanceEServer(Session session)
+ {
+ var Result = ActionResult.Success;
+ Log.WriteStart("MaintenanceEServer");
+ Result = ProcessInstall(session, WiXInstallType.MaintenanceEnterpriseServer);
+ Log.WriteEnd("MaintenanceEServer");
+ return Result;
+ }
+ [CustomAction]
+ public static ActionResult MaintenancePortal(Session session)
+ {
+ var Result = ActionResult.Success;
+ Log.WriteStart("MaintenancePortal");
+ Result = ProcessInstall(session, WiXInstallType.MaintenancePortal);
+ Log.WriteEnd("MaintenancePortal");
+ return Result;
+ }
+ [CustomAction]
public static ActionResult PreFillSettings(Session session)
{
PopUpDebugger();
@@ -733,18 +760,27 @@ namespace WebsitePanel.WIXInstaller
case WiXInstallType.RemoveServer:
Install = ServerSetup.Create(Ctx.CustomActionData, SetupActions.Uninstall);
break;
+ case WiXInstallType.MaintenanceServer:
+ Install = ServerSetup.Create(Ctx.CustomActionData, SetupActions.Setup);
+ break;
case WiXInstallType.InstallEnterpriseServer:
Install = EServerSetup.Create(Ctx.CustomActionData, SetupActions.Install);
break;
case WiXInstallType.RemoveEnterpriseServer:
Install = EServerSetup.Create(Ctx.CustomActionData, SetupActions.Uninstall);
break;
+ case WiXInstallType.MaintenanceEnterpriseServer:
+ Install = EServerSetup.Create(Ctx.CustomActionData, SetupActions.Setup);
+ break;
case WiXInstallType.InstallPortal:
Install = PortalSetup.Create(Ctx.CustomActionData, SetupActions.Install);
break;
case WiXInstallType.RemovePortal:
Install = PortalSetup.Create(Ctx.CustomActionData, SetupActions.Uninstall);
break;
+ case WiXInstallType.MaintenancePortal:
+ Install = PortalSetup.Create(Ctx.CustomActionData, SetupActions.Setup);
+ break;
default:
throw new NotImplementedException();
}
@@ -796,7 +832,8 @@ namespace WebsitePanel.WIXInstaller
RemoveServer,
RemoveEnterpriseServer,
RemovePortal,
- RemoveUpdate,
- RestoreUpdate
+ MaintenanceServer,
+ MaintenanceEnterpriseServer,
+ MaintenancePortal
}
}