mirror of
https://github.com/OrchardCMS/Orchard.git
synced 2025-09-22 20:13:50 +08:00
Tweaking a few aspects of the moment of setup
Sites subdirectory may need to be created Shouldn't write out the site-exists file until the setup transaction has committed Host reinitialize should be called outside of the lifetime of the temporary shell to avoid a xact deadlock --HG-- branch : dev
This commit is contained in:
@@ -33,6 +33,8 @@ namespace Orchard.Core.Settings.Services {
|
|||||||
item.Record.SiteName = "My Orchard Project Application";
|
item.Record.SiteName = "My Orchard Project Application";
|
||||||
item.Record.PageTitleSeparator = " - ";
|
item.Record.PageTitleSeparator = " - ";
|
||||||
});
|
});
|
||||||
|
// ensure subsequent calls will locate this object
|
||||||
|
_contentManager.Flush();
|
||||||
return site;
|
return site;
|
||||||
}
|
}
|
||||||
return _contentManager.Get<ISite>(record.Id);
|
return _contentManager.Get<ISite>(record.Id);
|
||||||
|
@@ -8,6 +8,7 @@ using Orchard.Data.Migrations;
|
|||||||
using Orchard.Environment;
|
using Orchard.Environment;
|
||||||
using Orchard.Environment.Configuration;
|
using Orchard.Environment.Configuration;
|
||||||
using Orchard.Security;
|
using Orchard.Security;
|
||||||
|
using Orchard.Settings;
|
||||||
using Orchard.Setup.ViewModels;
|
using Orchard.Setup.ViewModels;
|
||||||
using Orchard.Localization;
|
using Orchard.Localization;
|
||||||
using Orchard.UI.Notify;
|
using Orchard.UI.Notify;
|
||||||
@@ -55,24 +56,21 @@ namespace Orchard.Setup.Controllers {
|
|||||||
// components will exist entirely in isolation - no crossover between the safemode container currently in effect
|
// components will exist entirely in isolation - no crossover between the safemode container currently in effect
|
||||||
var shellSettings = new ShellSettings { Name = "temp" };
|
var shellSettings = new ShellSettings { Name = "temp" };
|
||||||
|
|
||||||
if (!_shellSettingsLoader.SaveSettings(shellSettings)) {
|
|
||||||
_notifier.Error(T("Site settings could not be saved. (Name = \"{0}\")", shellSettings.Name));
|
|
||||||
return Index(model);
|
|
||||||
}
|
|
||||||
|
|
||||||
using (var finiteEnvironment = _orchardHost.CreateStandaloneEnvironment(shellSettings)) {
|
using (var finiteEnvironment = _orchardHost.CreateStandaloneEnvironment(shellSettings)) {
|
||||||
var contentManager = finiteEnvironment.Resolve<IContentManager>();
|
var contentManager = finiteEnvironment.Resolve<IContentManager>();
|
||||||
|
|
||||||
// create superuser
|
// create superuser
|
||||||
var membershipService = finiteEnvironment.Resolve<IMembershipService>();
|
var membershipService = finiteEnvironment.Resolve<IMembershipService>();
|
||||||
var user = membershipService.CreateUser(new CreateUserParams(model.AdminUsername, model.AdminPassword, String.Empty, String.Empty, String.Empty, true));
|
var user = membershipService.CreateUser(new CreateUserParams(model.AdminUsername, model.AdminPassword, String.Empty, String.Empty, String.Empty, true));
|
||||||
|
|
||||||
// set site name and settings
|
// set site name and settings
|
||||||
contentManager.Create<SiteSettings>("site", item => {
|
var siteService = finiteEnvironment.Resolve<ISiteService>();
|
||||||
item.Record.SiteSalt = Guid.NewGuid().ToString("N");
|
var siteSettings = siteService.GetSiteSettings().As<SiteSettings>();
|
||||||
item.Record.SiteName = model.SiteName;
|
siteSettings.Record.SiteSalt = Guid.NewGuid().ToString("N");
|
||||||
item.Record.SuperUser = model.AdminUsername;
|
siteSettings.Record.SiteName = model.SiteName;
|
||||||
item.Record.PageTitleSeparator = " - ";
|
siteSettings.Record.SuperUser = model.AdminUsername;
|
||||||
});
|
siteSettings.Record.PageTitleSeparator = " - ";
|
||||||
|
|
||||||
// create home page as a CMS page
|
// create home page as a CMS page
|
||||||
var page = contentManager.Create("page");
|
var page = contentManager.Create("page");
|
||||||
@@ -86,9 +84,15 @@ namespace Orchard.Setup.Controllers {
|
|||||||
var authenticationService = finiteEnvironment.Resolve<IAuthenticationService>();
|
var authenticationService = finiteEnvironment.Resolve<IAuthenticationService>();
|
||||||
authenticationService.SignIn(user, true);
|
authenticationService.SignIn(user, true);
|
||||||
|
|
||||||
//_orchardHost.Reinitialize();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!_shellSettingsLoader.SaveSettings(shellSettings)) {
|
||||||
|
_notifier.Error(T("Site settings could not be saved. (Name = \"{0}\")", shellSettings.Name));
|
||||||
|
return Index(model);
|
||||||
|
}
|
||||||
|
|
||||||
|
_orchardHost.Reinitialize();
|
||||||
|
|
||||||
_notifier.Information(T("Setup succeeded"));
|
_notifier.Information(T("Setup succeeded"));
|
||||||
|
|
||||||
// redirect to the welcome page.
|
// redirect to the welcome page.
|
||||||
|
@@ -20,6 +20,9 @@ namespace Orchard.Environment.Configuration {
|
|||||||
if (settings != null && !string.IsNullOrEmpty(settings.Name)) {
|
if (settings != null && !string.IsNullOrEmpty(settings.Name)) {
|
||||||
var sitesPath = HostingEnvironment.MapPath("~/App_Data/Sites");
|
var sitesPath = HostingEnvironment.MapPath("~/App_Data/Sites");
|
||||||
if (sitesPath != null) {
|
if (sitesPath != null) {
|
||||||
|
if (!Directory.Exists(sitesPath))
|
||||||
|
Directory.CreateDirectory(sitesPath);
|
||||||
|
|
||||||
var filePath = Path.Combine(sitesPath, string.Format("{0}.txt", settings.Name));
|
var filePath = Path.Combine(sitesPath, string.Format("{0}.txt", settings.Name));
|
||||||
File.WriteAllText(filePath, ComposeSettings(settings));
|
File.WriteAllText(filePath, ComposeSettings(settings));
|
||||||
return true;
|
return true;
|
||||||
|
Reference in New Issue
Block a user