Updated VistaDB & MySQL Upgrade/Install scripts (My SQL still needs upgrade testing) Finalized Media Recycle Bin. Fixed Media optimized mode data layer call. Updated base installer interfaces/classes with more support. Fixes: 22493 [TFS Changeset #58897]
103 lines
3.2 KiB
C#
103 lines
3.2 KiB
C#
/************************************************************************************
|
|
*
|
|
* Umbraco Data Layer
|
|
* MIT Licensed work
|
|
* ©2008 Ruben Verborgh
|
|
*
|
|
***********************************************************************************/
|
|
|
|
using System;
|
|
using System.Resources;
|
|
using umbraco.DataLayer.Utility.Installer;
|
|
|
|
namespace umbraco.DataLayer.SqlHelpers.SqlServer
|
|
{
|
|
/// <summary>
|
|
/// Database installer for an SQL Server data source.
|
|
/// </summary>
|
|
public class SqlServerInstaller : DefaultInstallerUtility<SqlServerHelper>
|
|
{
|
|
#region Private Constants
|
|
|
|
/// <summary>The latest database version this installer supports.</summary>
|
|
private const DatabaseVersion LatestVersionSupported = DatabaseVersion.Version4_1;
|
|
|
|
/// <summary>The specifications to determine the database version.</summary>
|
|
private static readonly VersionSpecs[] m_VersionSpecs = new VersionSpecs[] {
|
|
new VersionSpecs("id","umbracoNode", "-21", DatabaseVersion.Version4_1),
|
|
new VersionSpecs("action","umbracoAppTree",DatabaseVersion.Version4),
|
|
new VersionSpecs("description","cmsContentType",DatabaseVersion.Version3),
|
|
new VersionSpecs("id","sysobjects",DatabaseVersion.None) };
|
|
|
|
#endregion
|
|
|
|
#region Public Properties
|
|
|
|
/// <summary>
|
|
/// Gets a value indicating whether the installer can upgrade the data source.
|
|
/// </summary>
|
|
/// <value>
|
|
/// <c>true</c> if the installer can upgrade the data source; otherwise, <c>false</c>.
|
|
/// </value>
|
|
/// <remarks>Empty data sources can't be upgraded, just installed.</remarks>
|
|
public override bool CanUpgrade
|
|
{
|
|
get
|
|
{
|
|
return CurrentVersion == DatabaseVersion.Version4;
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Protected Properties
|
|
|
|
/// <summary>
|
|
/// Gets the version specification for evaluation by DetermineCurrentVersion.
|
|
/// Only first matching specification is taken into account.
|
|
/// </summary>
|
|
/// <value>The version specifications.</value>
|
|
protected override VersionSpecs[] VersionSpecs
|
|
{
|
|
get { return m_VersionSpecs; }
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Public Constructors
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="SqlServerInstaller"/> class.
|
|
/// </summary>
|
|
/// <param name="sqlHelper">The SQL helper.</param>
|
|
public SqlServerInstaller(SqlServerHelper sqlHelper) : base(sqlHelper, LatestVersionSupported)
|
|
{ }
|
|
|
|
#endregion
|
|
|
|
#region DefaultInstaller Members
|
|
|
|
/// <summary>
|
|
/// Returns the sql to do a full install
|
|
/// </summary>
|
|
protected override string FullInstallSql
|
|
{
|
|
get { return SqlResources.Total; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Returns the sql to do an upgrade
|
|
/// </summary>
|
|
protected override string UpgradeSql
|
|
{
|
|
get
|
|
{
|
|
string upgradeFile = string.Format("{0}_Upgrade", CurrentVersion.ToString());
|
|
return SqlResources.ResourceManager.GetString(upgradeFile);
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
}
|
|
}
|