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;
}
}
}
|