geekbot/Geekbot.net/Lib/UserRepository/UserRepository.cs

80 lines
2.7 KiB
C#
Raw Normal View History

using System;
using System.Linq;
using System.Threading.Tasks;
using Discord.WebSocket;
using Geekbot.net.Database;
using Geekbot.net.Database.Models;
using Geekbot.net.Lib.Extensions;
using Geekbot.net.Lib.Logger;
namespace Geekbot.net.Lib.UserRepository
{
public class UserRepository : IUserRepository
{
private readonly DatabaseContext _database;
private readonly IGeekbotLogger _logger;
public UserRepository(DatabaseContext database, IGeekbotLogger logger)
{
_database = database;
_logger = logger;
}
public async Task<bool> Update(SocketUser user)
{
try
{
2017-10-26 23:31:51 +02:00
var savedUser = Get(user.Id);
var isNew = false;
if (savedUser == null)
{
savedUser = new UserModel();
isNew = true;
}
savedUser.UserId = user.Id.AsLong();
2017-10-26 23:31:51 +02:00
savedUser.Username = user.Username;
savedUser.Discriminator = user.Discriminator;
savedUser.AvatarUrl = user.GetAvatarUrl() ?? "";
2017-10-26 23:31:51 +02:00
savedUser.IsBot = user.IsBot;
savedUser.Joined = user.CreatedAt;
if (savedUser.UsedNames == null) savedUser.UsedNames = Enumerable.Empty<string>().ToArray();
2017-10-26 23:31:51 +02:00
if (!savedUser.UsedNames.Contains(user.Username))
{
savedUser.UsedNames = savedUser.UsedNames.Concat(new[] {user.Username}).ToArray();
}
if (isNew)
{
await _database.Users.AddAsync(savedUser);
}
else
{
_database.Users.Update(savedUser);
2017-10-26 23:31:51 +02:00
}
await _database.SaveChangesAsync();
_logger.Information(LogSource.UserRepository, "Updated User", savedUser);
await Task.Delay(500);
return true;
}
catch (Exception e)
{
_logger.Warning(LogSource.UserRepository, $"Failed to update user: {user.Username}#{user.Discriminator} ({user.Id})", e);
return false;
}
}
public UserModel Get(ulong userId)
2017-10-26 23:31:51 +02:00
{
try
{
return _database.Users.FirstOrDefault(u => u.UserId.Equals(userId.AsLong()));
2017-10-26 23:31:51 +02:00
}
catch (Exception e)
{
_logger.Warning(LogSource.UserRepository, $"Failed to get {userId} from repository", e);
return null;
}
}
}
}