blob: 0ee8dabd46ad1dd4365f57289a6df7f360a41145 (
plain)
| 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
 | using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Timeline.Entities;
using Timeline.Models.Validation;
namespace Timeline.Services.User
{
    public class BasicUserService : IBasicUserService
    {
        private readonly DatabaseContext _database;
        private readonly UsernameValidator _usernameValidator = new UsernameValidator();
        public BasicUserService(DatabaseContext database)
        {
            _database = database;
        }
        protected static EntityNotExistException CreateUserNotExistException(string username)
        {
            return new EntityNotExistException(EntityTypes.User,
                new Dictionary<string, object> { ["username"] = username });
        }
        protected static EntityNotExistException CreateUserNotExistException(long id)
        {
            return new EntityNotExistException(EntityTypes.User,
                new Dictionary<string, object> { ["id"] = id });
        }
        public async Task<bool> CheckUserExistenceAsync(long id)
        {
            return await _database.Users.AnyAsync(u => u.Id == id);
        }
        public async Task<long> GetUserIdByUsernameAsync(string username)
        {
            if (username == null)
                throw new ArgumentNullException(nameof(username));
            if (!_usernameValidator.Validate(username, out var message))
                throw new ArgumentException(message);
            var entity = await _database.Users.Where(user => user.Username == username).Select(u => new { u.Id }).SingleOrDefaultAsync();
            if (entity == null)
                throw CreateUserNotExistException(username);
            return entity.Id;
        }
        public async Task<DateTime> GetUsernameLastModifiedTimeAsync(long userId)
        {
            var entity = await _database.Users.Where(u => u.Id == userId).Select(u => new { u.UsernameChangeTime }).SingleOrDefaultAsync();
            if (entity is null)
                throw CreateUserNotExistException(userId);
            return entity.UsernameChangeTime;
        }
    }
}
 |