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 | 8efb9dc9bec7e52aa76a741d820bdeaf9eb45fec (patch) | |
tree | 73a1baa078fa7a38dcdbdd38620bba0ef6a1298f /BackEnd/Timeline/Models/Mapper/UserMapper.cs | |
parent | d3c9d0a9335ac6df3e330172b1b1a8a219cbdbaf (diff) | |
parent | 97e6ac51ac4df58cd1229e7974d2b846b192558a (diff) | |
download | timeline-8efb9dc9bec7e52aa76a741d820bdeaf9eb45fec.tar.gz timeline-8efb9dc9bec7e52aa76a741d820bdeaf9eb45fec.tar.bz2 timeline-8efb9dc9bec7e52aa76a741d820bdeaf9eb45fec.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;
}
}
}
|