Add VerificationToken for new members

This commit is contained in:
2019-12-16 14:42:55 -05:00
parent 7a4946f4f4
commit 0139d66d63
10 changed files with 130 additions and 63 deletions
+10 -1
View File
@@ -8,7 +8,7 @@ using Umbraco.Web;
using Umbraco.ModelsBuilder;
using Umbraco.ModelsBuilder.Umbraco;
[assembly: PureLiveAssembly]
[assembly:ModelsBuilderAssembly(PureLive = true, SourceHash = "79624ab1619e0f80")]
[assembly:ModelsBuilderAssembly(PureLive = true, SourceHash = "94dd4dfa3bd286e0")]
[assembly:System.Reflection.AssemblyVersion("0.0.0.1")]
@@ -586,6 +586,15 @@ namespace Umbraco.Web.PublishedContentModels
{
get { return this.GetPropertyValue<string>("umbracoMemberPasswordRetrievalQuestion"); }
}
///<summary>
/// Verification Token
///</summary>
[ImplementPropertyType("VerificationToken")]
public string VerificationToken
{
get { return this.GetPropertyValue<string>("VerificationToken"); }
}
}
}
+10 -1
View File
@@ -19,7 +19,7 @@ using Umbraco.ModelsBuilder;
using Umbraco.ModelsBuilder.Umbraco;
[assembly: PureLiveAssembly]
[assembly:ModelsBuilderAssembly(PureLive = true, SourceHash = "79624ab1619e0f80")]
[assembly:ModelsBuilderAssembly(PureLive = true, SourceHash = "94dd4dfa3bd286e0")]
[assembly:System.Reflection.AssemblyVersion("0.0.0.2")]
namespace Umbraco.Web.PublishedContentModels
@@ -570,6 +570,15 @@ namespace Umbraco.Web.PublishedContentModels
{
get { return this.GetPropertyValue<string>("umbracoMemberPasswordRetrievalQuestion"); }
}
///<summary>
/// Verification Token
///</summary>
[ImplementPropertyType("VerificationToken")]
public string VerificationToken
{
get { return this.GetPropertyValue<string>("VerificationToken"); }
}
}
}
+1 -1
View File
@@ -1 +1 @@
79624ab1619e0f80
94dd4dfa3bd286e0
+52
View File
@@ -0,0 +1,52 @@
using Hangfire;
using LeafWeb.WebCms.Services;
using MlkPwgen;
using Umbraco.Core;
using Umbraco.Core.Events;
using Umbraco.Core.Models;
using Umbraco.Core.Services;
namespace LeafWeb.WebCms.EventHandlers
{
// https://our.umbraco.com/forum/umbraco-7/using-umbraco-7/64185-Assign-new-members-to-member-group-upon-registration#comment-254768
public class MemberEvents : ApplicationEventHandler
{
protected override void ApplicationStarted(UmbracoApplicationBase umbracoApplication, ApplicationContext applicationContext)
{
base.ApplicationStarted(umbracoApplication, applicationContext);
MemberService.Created += MemberService_Created;
MemberService.Saving += MemberService_OnSaving;
}
private void MemberService_OnSaving(IMemberService sender, SaveEventArgs<IMember> e)
{
foreach (var member in e.SavedEntities)
{
// Member is not approved, don't send an email at all
if (!member.HasIdentity || !member.IsApproved)
continue;
// Pull the old approval state from the member service (this is the value before the save has updated the cache)
var alreadyApproved = ApplicationContext.Current.Services.MemberService.GetById(member.Id).IsApproved;
//Member wasn't approved before save but is now
if (!alreadyApproved)
{
//Code to send email goes here
}
}
}
private void MemberService_Created(IMemberService sender, NewEventArgs<IMember> e)
{
e.Entity.IsApproved = false;
var token = PasswordGenerator.Generate(12, allowed: "0123456789");
e.Entity.SetValue("VerificationToken", token);
sender.Save(e.Entity);
// Send Email
BackgroundJob.Enqueue<EmailNotificationService>(
email => email.SendVerifyMemberEmail(e.Entity.Email));
}
}
}
@@ -1,29 +0,0 @@
using Hangfire;
using LeafWeb.WebCms.Services;
using Umbraco.Core;
using Umbraco.Core.Events;
using Umbraco.Core.Models;
using Umbraco.Core.Services;
namespace LeafWeb.WebCms.EventHandlers
{
// https://our.umbraco.com/forum/umbraco-7/using-umbraco-7/64185-Assign-new-members-to-member-group-upon-registration#comment-254768
public class MemberRegistrationEventHandler : ApplicationEventHandler
{
protected override void ApplicationStarted(UmbracoApplicationBase umbracoApplication, ApplicationContext applicationContext)
{
base.ApplicationStarted(umbracoApplication, applicationContext);
MemberService.Created += MemberService_Created;
}
private void MemberService_Created(IMemberService sender, NewEventArgs<IMember> e)
{
sender.AssignRole(e.Entity.Username, "Unverified");
sender.Save(e.Entity);
// Send Email
BackgroundJob.Enqueue<EmailNotificationService>(
email => email.SendVerifyMemberEmail(e.Entity));
}
}
}
-22
View File
@@ -1,22 +0,0 @@
using System.Configuration;
using LeafWeb.Core.Entities;
namespace LeafWeb.WebCms.Services
{
public class DownloadUrlService
{
private readonly string _downloadUrl;
public DownloadUrlService()
{
_downloadUrl =
ConfigurationManager.AppSettings["LeafWebUrl"]
+ ConfigurationManager.AppSettings["ResultsDownloadPath"];
}
public string GetDownloadUrl(LeafInput leafInput)
{
return string.Format(_downloadUrl, leafInput.UniqueToken);
}
}
}
+18 -7
View File
@@ -7,7 +7,11 @@ using LeafWeb.Core.DAL;
using LeafWeb.Core.Entities;
using LeafWeb.Core.Utility;
using LeafWeb.WebCms.Models;
using Umbraco.Core;
using Umbraco.Core.Models;
using Umbraco.Web;
using Umbraco.Web.PublishedCache;
using Umbraco.Web.Security;
namespace LeafWeb.WebCms.Services
{
@@ -32,7 +36,7 @@ namespace LeafWeb.WebCms.Services
private readonly DataService _dataService;
private readonly DownloadUrlService _downloadUrlService;
private readonly UrlService _urlService;
private string FormatSubject(string subject, LeafInput leafInput)
{
@@ -43,7 +47,7 @@ namespace LeafWeb.WebCms.Services
{
_dataService = dataService;
_downloadUrlService = new DownloadUrlService();
_urlService = new UrlService();
_smtpClient = new SmtpClient(
ConfigurationManager.AppSettings["SmtpHost"],
@@ -114,7 +118,7 @@ namespace LeafWeb.WebCms.Services
if (downloadLink)
{
var downloadUrl = _downloadUrlService.GetDownloadUrl(leafInput);
var downloadUrl = _urlService.GetDownloadUrl(leafInput);
body +=
"Download results with the following link:"
@@ -197,12 +201,18 @@ namespace LeafWeb.WebCms.Services
SendMessage(message);
}
public void SendVerifyMemberEmail(IMember member)
public void SendVerifyMemberEmail(string memberEmail)
{
// TODO: write verify email to user
var servicesMemberService = ApplicationContext.Current.Services.MemberService;
var member = servicesMemberService.GetByEmail(memberEmail);
var verifyEmailURl = _urlService.GetVerifyEmailURl(member);
var body = "Please verify your email address with this link " + verifyEmailURl;
var message = new MailMessage(_emailFromAddress, member.Email, "Verify your email for LeafWeb", body);
SendMessage(message);
}
private string FormatWarningMessage(LeafInput leafInput)
private string FormatWarningMessage(LeafInput leafInput)
{
if (leafInput.OutputWarningMessage != null)
return Environment.NewLine + Environment.NewLine
@@ -230,5 +240,6 @@ namespace LeafWeb.WebCms.Services
{
_dataService.Dispose();
}
}
}
}
+33
View File
@@ -0,0 +1,33 @@
using System.Configuration;
using LeafWeb.Core.Entities;
using Umbraco.Core.Models;
using Umbraco.Web.PublishedCache;
namespace LeafWeb.WebCms.Services
{
public class UrlService
{
private readonly string _downloadUrl;
private readonly string _verifyEmailUrl;
public UrlService()
{
_downloadUrl =
ConfigurationManager.AppSettings["LeafWebUrl"]
+ ConfigurationManager.AppSettings["ResultsDownloadPath"];
}
public string GetDownloadUrl(LeafInput leafInput)
{
return string.Format(_downloadUrl, leafInput.UniqueToken);
}
public string GetVerifyEmailURl(IMember member)
{
var memberEmail = member.Email;
var token = member.GetValue("VerificationToken") as string;
var verifyEmailToken = _downloadUrl + "/verify?email={0}&token={1}";
return string.Format(verifyEmailToken, memberEmail, token);
}
}
}
+5 -2
View File
@@ -187,6 +187,9 @@
<HintPath>..\packages\MiniProfiler.2.1.0\lib\net40\MiniProfiler.dll</HintPath>
<Private>True</Private>
</Reference>
<Reference Include="MlkPwgen, Version=0.3.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\packages\MlkPwgen.0.3.0\lib\net45\MlkPwgen.dll</HintPath>
</Reference>
<Reference Include="MySql.Data, Version=6.9.9.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d, processorArchitecture=MSIL">
<HintPath>..\packages\MySql.Data.6.9.9\lib\net45\MySql.Data.dll</HintPath>
<Private>True</Private>
@@ -1097,7 +1100,7 @@
<Compile Include="Controllers\LeafWebPageIds.cs" />
<Compile Include="Controllers\QueueController.cs" />
<Compile Include="Controllers\ResultsController.cs" />
<Compile Include="EventHandlers\MemberRegistrationEventHandler.cs" />
<Compile Include="EventHandlers\MemberEvents.cs" />
<Compile Include="Models\ChartViewModel.cs" />
<Compile Include="Models\ContactForm.cs" />
<Compile Include="Models\LeafInputDetails.cs" />
@@ -1106,7 +1109,7 @@
<Compile Include="Models\QueueViewModel.cs" />
<Compile Include="Models\SelectListViewModel.cs" />
<Compile Include="Properties\AssemblyInfo.cs" />
<Compile Include="Services\DownloadUrlService.cs" />
<Compile Include="Services\UrlService.cs" />
<Compile Include="Services\EmailNotificationService.cs" />
<Compile Include="Services\LeafGasCharter.cs" />
<Compile Include="Services\PiscalQueue\FinishComplete.cs" />
+1
View File
@@ -54,6 +54,7 @@
<package id="Microsoft.Owin.Security.OAuth" version="4.1.0" targetFramework="net452" />
<package id="Microsoft.Web.Infrastructure" version="1.0.0.0" targetFramework="net452" />
<package id="MiniProfiler" version="2.1.0" targetFramework="net452" />
<package id="MlkPwgen" version="0.3.0" targetFramework="net452" />
<package id="MySql.Data" version="6.9.9" targetFramework="net452" />
<package id="NETStandard.Library" version="2.0.3" targetFramework="net452" />
<package id="Newtonsoft.Json" version="12.0.3" targetFramework="net452" />