-
Notifications
You must be signed in to change notification settings - Fork 162
/
Copy pathTenantAdminController.cs
109 lines (90 loc) · 4.21 KB
/
TenantAdminController.cs
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
using Microsoft.AspNetCore.Mvc;
using System.Linq;
using System.Threading.Tasks;
using AuthPermissions.AdminCode;
using AuthPermissions.AspNetCore;
using AuthPermissions.BaseCode.CommonCode;
using AuthPermissions.SupportCode.AddUsersServices;
using Example3.MvcWebApp.IndividualAccounts.Models;
using Example3.MvcWebApp.IndividualAccounts.PermissionsCode;
using ExamplesCommonCode.CommonAdmin;
using Microsoft.EntityFrameworkCore;
namespace Example3.MvcWebApp.IndividualAccounts.Controllers
{
public class TenantAdminController : Controller
{
private readonly IAuthUsersAdminService _authUsersAdmin;
public TenantAdminController(IAuthUsersAdminService authUsersAdmin)
{
_authUsersAdmin = authUsersAdmin;
}
[HasPermission(Example3Permissions.UserRead)]
public async Task<IActionResult> Index(string message)
{
var dataKey = User.GetAuthDataKeyFromUser();
var userQuery = _authUsersAdmin.QueryAuthUsers(dataKey);
var usersToShow = await AuthUserDisplay.TurnIntoDisplayFormat(userQuery.OrderBy(x => x.Email)).ToListAsync();
ViewBag.Message = message;
return View(usersToShow);
}
[HasPermission(Example3Permissions.UserRolesChange)]
public async Task<ActionResult> EditRoles(string userId)
{
var status = await SetupManualUserChange.PrepareForUpdateAsync(userId, _authUsersAdmin);
if (status.HasErrors)
return RedirectToAction(nameof(ErrorDisplay),
new { errorMessage = status.GetAllErrors() });
return View(status.Result);
}
[HttpPost]
[ValidateAntiForgeryToken]
[HasPermission(Example3Permissions.UserRolesChange)]
public async Task<ActionResult> EditRoles(SetupManualUserChange change)
{
var status = await _authUsersAdmin.UpdateUserAsync(change.UserId,
roleNames: change.RoleNames);
if (status.HasErrors)
return RedirectToAction(nameof(ErrorDisplay),
new { errorMessage = status.GetAllErrors() });
return RedirectToAction(nameof(Index), new { message = status.Message });
}
[HasPermission(Example3Permissions.InviteUsers)]
public async Task<ActionResult> InviteUser([FromServices] IInviteNewUserService inviteService)
{
var setupInvite = new InviteUserSetup
{
AllRoleNames = await _authUsersAdmin.GetRoleNamesForUsersAsync(User.GetUserIdFromUser()),
ExpirationTimesDropdown = inviteService.ListOfExpirationTimes()
};
return View(setupInvite);
}
[HasPermission(Example3Permissions.InviteUsers)]
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> InviteUser([FromServices] IInviteNewUserService inviteUserServiceService, InviteUserSetup data)
{
var addUserData = new AddNewUserDto { Email = data.Email, Roles = data.RoleNames,
TimeInviteExpires = data.InviteExpiration};
var status = await inviteUserServiceService.CreateInviteUserToJoinAsync(addUserData, User.GetUserIdFromUser());
if (status.HasErrors)
return RedirectToAction(nameof(ErrorDisplay),
new { errorMessage = status.GetAllErrors() });
var inviteUrl = AbsoluteAction(Url, nameof(HomeController.AcceptInvite), "Home", new { verify = status.Result });
return View("InviteUserUrl", new InviteUserResult( status.Message, inviteUrl));
}
public ActionResult ErrorDisplay(string errorMessage)
{
return View((object)errorMessage);
}
//-------------------------------------------------------
//Thanks to https://stackoverflow.com/questions/30755827/getting-absolute-urls-using-asp-net-core
public string AbsoluteAction(IUrlHelper url,
string actionName,
string controllerName,
object routeValues = null)
{
string scheme = HttpContext.Request.Scheme;
return url.Action(actionName, controllerName, routeValues, scheme);
}
}
}