-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathModule.cs
More file actions
54 lines (47 loc) · 2.94 KB
/
Module.cs
File metadata and controls
54 lines (47 loc) · 2.94 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
using DevExpress.ExpressApp;
using DevExpress.ExpressApp.Actions;
using DevExpress.Persistent.Base.Security;
using Microsoft.Extensions.DependencyInjection;
using Security.Extensions.Controllers;
using Security.Extensions.Services;
using System.Collections.Generic;
namespace Security.Extensions;
// A delegate that, when invoked, creates and returns a new user with the specified user name, password and email address.
public delegate IAuthenticationStandardUser CreateSecuritySystemUser(IObjectSpace objectSpace, string userName, string email, string password, bool isAdministrator);
public sealed class SecurityExtensionsModule : ModuleBase {
public SecurityExtensionsModule() {
RequiredModuleTypes.Add(typeof(DevExpress.ExpressApp.Security.SecurityModule));
RequiredModuleTypes.Add(typeof(DevExpress.ExpressApp.Validation.ValidationModule));
}
public override void Setup(XafApplication application) {
base.Setup(application);
application.CreateCustomLogonWindowControllers += application_CreateCustomLogonWindowControllers;
application.CreateCustomLogonAction += Application_CreateCustomLogonAction;
}
private void application_CreateCustomLogonWindowControllers(object sender, CreateCustomLogonWindowControllersEventArgs e) {
var application = (XafApplication)sender;
e.Controllers.Add(application.CreateController<ManageUsersOnLogonController>());
e.Controllers.Add(application.CreateController<LogonActionCustomizationController>());
}
private void Application_CreateCustomLogonAction(object sender, CreateCustomLogonActionEventArgs e) {
var restorePasswordService = Application.ServiceProvider.GetRequiredService<RestorePasswordService>();
var restorePasswordToken = restorePasswordService.GetRestorePasswordTokenFromUrl();
if (!string.IsNullOrEmpty(restorePasswordToken)) {
var logonWindowControllers = e.CreateLogonWindowControllers();
e.LogonAction = CreateRestorePasswordLogonAction(restorePasswordToken, logonWindowControllers);
}
}
private PopupWindowShowAction CreateRestorePasswordLogonAction(string restorePasswordToken, List<Controller> logonWindowControllers) {
var restorePasswordLogonAction = new PopupWindowShowAction();
restorePasswordLogonAction.Application = Application;
restorePasswordLogonAction.CustomizePopupWindowParams += (s, e) => {
var objectSpace = Application.CreateObjectSpace<SetNewPasswordParameters>();
var newPasswordParameters = objectSpace.CreateObject<SetNewPasswordParameters>();
newPasswordParameters.Token = restorePasswordToken;
e.View = Application.CreateDetailView(objectSpace, newPasswordParameters);
e.DialogController = Application.CreateController<LogonController>();
e.DialogController.Controllers.AddRange(logonWindowControllers);
};
return restorePasswordLogonAction;
}
}