Moves the registration logic to the MembershipHelper, fixes up the views to keep the indexes so props save.

This commit is contained in:
Shannon
2014-01-28 21:42:30 +11:00
parent 1bfdd83ba7
commit cfd0973f00
7 changed files with 87 additions and 38 deletions

View File

@@ -38,11 +38,11 @@
@Html.ValidationMessageFor(m => profileModel.Email)
<br />
@foreach (var prop in profileModel.MemberProperties)
@for (var i = 0; i < profileModel.MemberProperties.Count; i++)
{
@Html.LabelFor(m => prop.Value, prop.Name)
@Html.EditorFor(m => prop.Value)
@Html.HiddenFor(m => prop.Alias)
@Html.LabelFor(m => profileModel.MemberProperties[i].Value, profileModel.MemberProperties[i].Name)
@Html.EditorFor(m => profileModel.MemberProperties[i].Value)
@Html.HiddenFor(m => profileModel.MemberProperties[i].Alias)
<br />
}

View File

@@ -70,12 +70,12 @@ else
@Html.ValidationMessageFor(m => registerModel.Password)
<br />
@if (registerModel.MemberProperties != null) {
foreach (var prop in registerModel.MemberProperties)
@if (registerModel.MemberProperties != null) {
for (var i = 0; i < registerModel.MemberProperties.Count; i++)
{
@Html.LabelFor(m => prop.Value, prop.Name)
@Html.EditorFor(m => prop.Value)
@Html.HiddenFor(m => prop.Alias)
@Html.LabelFor(m => registerModel.MemberProperties[i].Value, registerModel.MemberProperties[i].Name)
@Html.EditorFor(m => registerModel.MemberProperties[i].Value)
@Html.HiddenFor(m => registerModel.MemberProperties[i].Alias)
<br />
}
}

View File

@@ -1,4 +1,4 @@
@inherits Umbraco.Web.Macros.PartialViewMacroPage
@inherits Umbraco.Web.Mvc.UmbracoTemplatePage
@using System.Web.Mvc.Html
@using ClientDependency.Core.Mvc
@@ -38,11 +38,11 @@
@Html.ValidationMessageFor(m => profileModel.Email)
<br />
@foreach (var prop in profileModel.MemberProperties)
@for (var i = 0; i < profileModel.MemberProperties.Count; i++)
{
@Html.LabelFor(m => prop.Value, prop.Name)
@Html.EditorFor(m => prop.Value)
@Html.HiddenFor(m => prop.Alias)
@Html.LabelFor(m => profileModel.MemberProperties[i].Value, profileModel.MemberProperties[i].Name)
@Html.EditorFor(m => profileModel.MemberProperties[i].Value)
@Html.HiddenFor(m => profileModel.MemberProperties[i].Alias)
<br />
}

View File

@@ -71,11 +71,11 @@ else
<br />
@if (registerModel.MemberProperties != null) {
foreach (var prop in registerModel.MemberProperties)
for (var i = 0; i < registerModel.MemberProperties.Count; i++)
{
@Html.LabelFor(m => prop.Value, prop.Name)
@Html.EditorFor(m => prop.Value)
@Html.HiddenFor(m => prop.Alias)
@Html.LabelFor(m => registerModel.MemberProperties[i].Value, registerModel.MemberProperties[i].Name)
@Html.EditorFor(m => registerModel.MemberProperties[i].Value)
@Html.HiddenFor(m => registerModel.MemberProperties[i].Alias)
<br />
}
}
@@ -86,6 +86,6 @@ else
@Html.HiddenFor(m => registerModel.UsernameIsEmail)
<button>Register</button>
</fieldset>
</fieldset>
}
}

View File

@@ -4,6 +4,7 @@ using System.Web.Mvc;
using System.Web.Security;
using umbraco.BusinessLogic;
using umbraco.cms.businesslogic.member;
using Umbraco.Core.Security;
using Umbraco.Web.Models;
using Umbraco.Web.Mvc;
@@ -19,32 +20,18 @@ namespace Umbraco.Web.Controllers
return CurrentUmbracoPage();
}
model.Username = (model.UsernameIsEmail || model.Username == null) ? model.Email : model.Username;
MembershipCreateStatus status;
var member = Membership.CreateUser(model.Username, model.Password, model.Email,
//TODO: Support q/a http://issues.umbraco.org/issue/U4-3213
null, null,
true, out status);
var member = Members.RegisterMember(model, out status, model.LoginOnSuccess);
switch (status)
{
case MembershipCreateStatus.Success:
//Set member online
Membership.GetUser(model.Username, true);
//Log them in
FormsAuthentication.SetAuthCookie(member.UserName, true);
if (model.RedirectOnSucces)
{
return Redirect(model.RedirectUrl);
}
TempData.Add("FormSuccess", true);
return RedirectToCurrentUmbracoPage();
break;
case MembershipCreateStatus.InvalidUserName:
ModelState.AddModelError((model.UsernameIsEmail || model.Username == null)
? "registerModel.Email"

View File

@@ -28,6 +28,7 @@ namespace Umbraco.Web.Models
RedirectUrl = "/";
UsernameIsEmail = true;
MemberProperties = new List<UmbracoProperty>();
LoginOnSuccess = true;
if (doLookup && HttpContext.Current != null && ApplicationContext.Current != null)
{
@@ -67,5 +68,11 @@ namespace Umbraco.Web.Models
public string Username { get; set; }
public bool UsernameIsEmail { get; set; }
/// <summary>
/// Specifies if the member should be logged in if they are succesfully created
/// </summary>
public bool LoginOnSuccess { get; set; }
}
}

View File

@@ -47,6 +47,57 @@ namespace Umbraco.Web.Security
return Membership.Provider.IsUmbracoMembershipProvider();
}
/// <summary>
/// Registers a new member
/// </summary>
/// <param name="model"></param>
/// <param name="status"></param>
/// <param name="logMemberIn">
/// true to log the member in upon successful registration
/// </param>
/// <returns></returns>
public MembershipUser RegisterMember(RegisterModel model, out MembershipCreateStatus status, bool logMemberIn = true)
{
model.Username = (model.UsernameIsEmail || model.Username == null) ? model.Email : model.Username;
var membershipUser = Membership.CreateUser(model.Username, model.Password, model.Email,
//TODO: Support q/a http://issues.umbraco.org/issue/U4-3213
null, null,
true, out status);
if (status != MembershipCreateStatus.Success) return null;
//update their real name
if (Membership.Provider.IsUmbracoMembershipProvider())
{
var member = _applicationContext.Services.MemberService.GetByUsername(membershipUser.UserName);
member.Name = model.Name;
if (model.MemberProperties != null)
{
foreach (var property in model.MemberProperties.Where(p => p.Value != null)
.Where(property => member.Properties.Contains(property.Alias)))
{
member.Properties[property.Alias].Value = property.Value;
}
}
_applicationContext.Services.MemberService.Save(member);
}
else
{
//TODO: Support this scenario!
}
//Set member online
Membership.GetUser(model.Username, true);
//Log them in
FormsAuthentication.SetAuthCookie(membershipUser.UserName, true);
return membershipUser;
}
/// <summary>
/// A helper method to perform the validation and logging in of a member - this is simply wrapping standard membership provider and asp.net forms auth logic.
/// </summary>
@@ -161,15 +212,19 @@ namespace Umbraco.Web.Security
/// <returns></returns>
public LoginStatusModel GetCurrentLoginStatus()
{
if (IsLoggedIn() == false)
return null;
var model = LoginStatusModel.CreateModel();
if (IsLoggedIn() == false)
{
model.IsLoggedIn = false;
return model;
}
if (Membership.Provider.IsUmbracoMembershipProvider())
{
var member = GetCurrentMember();
//this shouldn't happen
if (member == null) return null;
if (member == null) return model;
model.Name = member.Name;
model.Username = member.Username;
model.Email = member.Email;