* Add new BackOfficeApi project * Add swagger * Add and route new install controller * Add new install steps * Add Setup endpoint * Add missing RequiresExecution methods * Fix nullability of databasemodel * Move user information to separate model * Remove ping method * Add view models install data * Move mapping folder * Move ViewModels * Add settings endpoint * Remove unused binderprovider * Postfix RequiresExecution with async * Update NewDatabaseUpgradeStep to not depend on install step * Add installstep collection * Move registration into backoffice project * Add InstallService * Use service in controller * Add upgrade to install service and use in controller * Correctly check is database is configured * Reorganize * Reorganize into new core and infrastructure * Rename steps * Rename BackofficeApi to MangementApi * Make install step an interface instead of abstract class * Rename InstallStep to create CreateUserStep * Move restart runtime and sign in user into install steps * Move install service into new core project * Map controllers in composer * Restrict access to installcontroller based on runtime level * Use FireAndForget when logging install * Use actionresult instead of iactionresult * Set new projects as not packable * Link to backoffice in 201 response when installed * Register installations * Add custom backoffice routing template token * Move umbraco path trimming out of application convention * Make it easier to route to backoffice api * Make swagger version aware and move behind backoffice path * Obsolete old install classes * Move maps into single file This is all mappint to/from viewmodels in some manner * Remove usage of InstallSetupResult * Move new projects to the src folder * Remove InstallationType from IInstallStep This upgrade steps should implement their own IUpgradeStep interface * Remove upgrade from service and controller This should be its own service and controller * Add xml docs * Remove internals visible to * Disable package validation for new projects Quite the gotcha here, if the projects are brand new, there is no nuget packages to compare with, this causes the build to fail. * Add ValidateDatabase endpoint * Remove project references to new backoffice We don't actually want to depend on this yet, it's just needed for testing/development * Obsolete installationtype * Add DatabaseSettingsFactory tests * Add InstallServiceTests * Fix InstallServiceTests * Test RequireRuntimeLevelAttribute * Implement new backoffice upgrader (#12818) * Add UpgradeSettingsModel and viewmodel * Add upgrade/settings endpoint * Implement upgrade steps * Add upgrade step collection * Add UpgradeService * Add authorize endpoint to UpgradeController * Fix interface * Add upgrade service tests * Remove runtime check in databaseinstallstep * Move RequireRuntimeLevel to controller * Add a readme to the new backoffice part * BackOffice not Backoffice * Add conditional project references * Fixes based on review * Fix up * Move running of steps into its own method in UpgradeService * Make services transient * More fixup * Log exceptions when running steps
57 lines
2.3 KiB
C#
57 lines
2.3 KiB
C#
using Umbraco.Cms.Core.Configuration;
|
|
using Umbraco.Cms.Core.Install.Models;
|
|
using Umbraco.Cms.Core.Semver;
|
|
using Umbraco.Cms.Core.Services;
|
|
using Umbraco.Extensions;
|
|
namespace Umbraco.Cms.Core.Install.InstallSteps
|
|
{
|
|
/// <summary>
|
|
/// This step is purely here to show the button to commence the upgrade
|
|
/// </summary>
|
|
[Obsolete("Will be replace with a new step with the new backoffice")]
|
|
[InstallSetupStep(InstallationType.Upgrade, "Upgrade", "upgrade", 1, "Upgrading Umbraco to the latest and greatest version.")]
|
|
public class UpgradeStep : InstallSetupStep<object>
|
|
{
|
|
public override bool RequiresExecution(object model) => true;
|
|
private readonly IUmbracoVersion _umbracoVersion;
|
|
private readonly IRuntimeState _runtimeState;
|
|
|
|
public UpgradeStep(IUmbracoVersion umbracoVersion, IRuntimeState runtimeState)
|
|
{
|
|
_umbracoVersion = umbracoVersion;
|
|
_runtimeState = runtimeState;
|
|
}
|
|
|
|
public override Task<InstallSetupResult?> ExecuteAsync(object model) => Task.FromResult<InstallSetupResult?>(null);
|
|
|
|
public override object ViewModel
|
|
{
|
|
get
|
|
{
|
|
string FormatGuidState(string? value)
|
|
{
|
|
if (string.IsNullOrWhiteSpace(value))
|
|
{
|
|
value = "unknown";
|
|
}
|
|
else if (Guid.TryParse(value, out Guid currentStateGuid))
|
|
{
|
|
value = currentStateGuid.ToString("N").Substring(0, 8);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
var currentState = FormatGuidState(_runtimeState.CurrentMigrationState);
|
|
var newState = FormatGuidState(_runtimeState.FinalMigrationState);
|
|
var newVersion = _umbracoVersion.SemanticVersion?.ToSemanticStringWithoutBuild();
|
|
var oldVersion = new SemVersion(_umbracoVersion.SemanticVersion?.Major ?? 0).ToString(); //TODO can we find the old version somehow? e.g. from current state
|
|
|
|
var reportUrl = $"https://our.umbraco.com/contribute/releases/compare?from={oldVersion}&to={newVersion}¬es=1";
|
|
|
|
return new { oldVersion, newVersion, currentState, newState, reportUrl };
|
|
}
|
|
}
|
|
}
|
|
}
|