diff options
author | crupest <crupest@outlook.com> | 2021-01-07 20:14:55 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-07 20:14:55 +0800 |
commit | e02871ff8bba7fccebdaaeea29141ed5e3289c09 (patch) | |
tree | 67128b91d6cfd08c54c9e745e7bf2abbdf1f20f4 /BackEnd/Timeline/Models/Mapper/UserMapper.cs | |
parent | 5ad1b1f0191ee1131e7808c8fcb0484ba29c0d4d (diff) | |
parent | ffe44ba70c9e5c6a01179c7e2f4185543cbc441c (diff) | |
download | timeline-e02871ff8bba7fccebdaaeea29141ed5e3289c09.tar.gz timeline-e02871ff8bba7fccebdaaeea29141ed5e3289c09.tar.bz2 timeline-e02871ff8bba7fccebdaaeea29141ed5e3289c09.zip |
Merge pull request #203 from crupest/back-dev
refactor: Make mapper a service. Fix #202.
Diffstat (limited to 'BackEnd/Timeline/Models/Mapper/UserMapper.cs')
-rw-r--r-- | BackEnd/Timeline/Models/Mapper/UserMapper.cs | 31 |
1 files changed, 20 insertions, 11 deletions
diff --git a/BackEnd/Timeline/Models/Mapper/UserMapper.cs b/BackEnd/Timeline/Models/Mapper/UserMapper.cs index 3255dca9..e6db4225 100644 --- a/BackEnd/Timeline/Models/Mapper/UserMapper.cs +++ b/BackEnd/Timeline/Models/Mapper/UserMapper.cs @@ -1,6 +1,6 @@ using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;
-using System.Linq;
+using System.Threading.Tasks;
using Timeline.Controllers;
using Timeline.Entities;
using Timeline.Models.Http;
@@ -8,15 +8,24 @@ using Timeline.Services; namespace Timeline.Models.Mapper
{
- public static class UserMapper
+ public class UserMapper
{
- public static HttpUser MapToHttp(this UserEntity entity, IUrlHelper urlHelper)
+ private readonly DatabaseContext _database;
+ private readonly IUserPermissionService _userPermissionService;
+
+ public UserMapper(DatabaseContext database, IUserPermissionService userPermissionService)
+ {
+ _database = database;
+ _userPermissionService = userPermissionService;
+ }
+
+ public async Task<HttpUser> MapToHttp(UserEntity entity, IUrlHelper urlHelper)
{
return new HttpUser(
uniqueId: entity.UniqueId,
username: entity.Username,
nickname: string.IsNullOrEmpty(entity.Nickname) ? entity.Username : entity.Nickname,
- permissions: MapPermission(entity),
+ permissions: (await _userPermissionService.GetPermissionsOfUserAsync(entity.Id, false)).ToStringList(),
links: new HttpUserLinks(
self: urlHelper.ActionLink(nameof(UserController.Get), nameof(UserController)[0..^nameof(Controller).Length], new { entity.Username }),
avatar: urlHelper.ActionLink(nameof(UserAvatarController.Get), nameof(UserAvatarController)[0..^nameof(Controller).Length], new { entity.Username }),
@@ -25,14 +34,14 @@ namespace Timeline.Models.Mapper );
}
- public static List<HttpUser> MapToHttp(this List<UserEntity> entities, IUrlHelper urlHelper)
- {
- return entities.Select(e => e.MapToHttp(urlHelper)).ToList();
- }
-
- private static List<string> MapPermission(UserEntity entity)
+ public async Task<List<HttpUser>> MapToHttp(List<UserEntity> entities, IUrlHelper urlHelper)
{
- return entity.Permissions.Select(p => p.Permission).ToList();
+ var result = new List<HttpUser>();
+ foreach (var entity in entities)
+ {
+ result.Add(await MapToHttp(entity, urlHelper));
+ }
+ return result;
}
}
}
|