152 lines
6.0 KiB
C#
152 lines
6.0 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Collections.Specialized;
|
|
using System.Configuration;
|
|
using System.Web;
|
|
using System.Web.Security;
|
|
using Umbraco.Core;
|
|
using Umbraco.Core.Configuration;
|
|
using Umbraco.Core.Persistence;
|
|
using Umbraco.Web.Install.Models;
|
|
|
|
namespace Umbraco.Web.Install.InstallSteps
|
|
{
|
|
/// <summary>
|
|
/// This is the first UI step for a brand new install
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// By default this will show the user view which is the most basic information to configure a new install, but if an install get's interupted because of an
|
|
/// error, etc... and the end-user refreshes the installer then we cannot show the user screen because they've already entered that information so instead we'll
|
|
/// display a simple continue installation view.
|
|
/// </remarks>
|
|
[InstallSetupStep(InstallationType.NewInstall,
|
|
"User", 20, "")]
|
|
internal class NewInstallStep : InstallSetupStep<UserModel>
|
|
{
|
|
private readonly HttpContextBase _http;
|
|
private readonly ApplicationContext _applicationContext;
|
|
|
|
public NewInstallStep(HttpContextBase http, ApplicationContext applicationContext)
|
|
{
|
|
_http = http;
|
|
_applicationContext = applicationContext;
|
|
}
|
|
|
|
//TODO: Change all logic in this step to use ASP.NET Identity NOT MembershipProviders
|
|
private MembershipProvider CurrentProvider
|
|
{
|
|
get
|
|
{
|
|
var provider = Core.Security.MembershipProviderExtensions.GetUsersMembershipProvider();
|
|
return provider;
|
|
}
|
|
}
|
|
|
|
public override InstallSetupResult Execute(UserModel user)
|
|
{
|
|
var admin = _applicationContext.Services.UserService.GetUserById(0);
|
|
if (admin == null)
|
|
{
|
|
throw new InvalidOperationException("Could not find the admi user!");
|
|
}
|
|
|
|
var membershipUser = CurrentProvider.GetUser(0, true);
|
|
if (membershipUser == null)
|
|
{
|
|
throw new InvalidOperationException("No user found in membership provider with id of 0");
|
|
}
|
|
|
|
try
|
|
{
|
|
var success = membershipUser.ChangePassword("default", user.Password.Trim());
|
|
if (success == false)
|
|
{
|
|
throw new FormatException("Password must be at least " + CurrentProvider.MinRequiredPasswordLength + " characters long and contain at least " + CurrentProvider.MinRequiredNonAlphanumericCharacters + " symbols");
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new FormatException("Password must be at least " + CurrentProvider.MinRequiredPasswordLength + " characters long and contain at least " + CurrentProvider.MinRequiredNonAlphanumericCharacters + " symbols");
|
|
}
|
|
|
|
admin.Email = user.Email.Trim();
|
|
admin.Name = user.Name.Trim();
|
|
admin.Username = user.Email.Trim();
|
|
|
|
_applicationContext.Services.UserService.Save(admin);
|
|
|
|
|
|
if (user.SubscribeToNewsLetter)
|
|
{
|
|
try
|
|
{
|
|
var client = new System.Net.WebClient();
|
|
var values = new NameValueCollection { { "name", admin.Name }, { "email", admin.Email} };
|
|
client.UploadValues("https://shop.umbraco.com/base/Ecom/SubmitEmail/installer.aspx", values);
|
|
}
|
|
catch { /* fail in silence */ }
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Return a custom view model for this step
|
|
/// </summary>
|
|
public override object ViewModel
|
|
{
|
|
get
|
|
{
|
|
var provider = Core.Security.MembershipProviderExtensions.GetUsersMembershipProvider();
|
|
|
|
return new
|
|
{
|
|
minCharLength = provider.MinRequiredPasswordLength,
|
|
minNonAlphaNumericLength = provider.MinRequiredNonAlphanumericCharacters
|
|
};
|
|
}
|
|
}
|
|
|
|
public override string View
|
|
{
|
|
get { return RequiresExecution(null)
|
|
//the user UI
|
|
? "user"
|
|
//the continue install UI
|
|
: "continueinstall"; }
|
|
}
|
|
|
|
public override bool RequiresExecution(UserModel model)
|
|
{
|
|
//now we have to check if this is really a new install, the db might be configured and might contain data
|
|
var databaseSettings = ConfigurationManager.ConnectionStrings[Constants.System.UmbracoConnectionName];
|
|
|
|
//if there's already a version then there should def be a user but in some cases someone may have
|
|
// left a version number in there but cleared out their db conn string, in that case, it's really a new install.
|
|
if (GlobalSettings.ConfigurationStatus.IsNullOrWhiteSpace() == false && databaseSettings != null) return false;
|
|
|
|
if (_applicationContext.DatabaseContext.IsConnectionStringConfigured(databaseSettings)
|
|
&& _applicationContext.DatabaseContext.IsDatabaseConfigured)
|
|
{
|
|
//check if we have the default user configured already
|
|
var result = _applicationContext.DatabaseContext.Database.ExecuteScalar<int>(
|
|
"SELECT COUNT(*) FROM umbracoUser WHERE id=0 AND userPassword='default'");
|
|
if (result == 1)
|
|
{
|
|
//the user has not been configured
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
// In this one case when it's a brand new install and nothing has been configured, make sure the
|
|
// back office cookie is cleared so there's no old cookies lying around causing problems
|
|
_http.ExpireCookie(UmbracoConfig.For.UmbracoSettings().Security.AuthCookieName);
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|