Adds user repo.
This commit is contained in:
parent
869aeb9253
commit
8ad2dee67c
@ -12,5 +12,8 @@ namespace BiblioTech
|
||||
|
||||
[Uniform("endpoints", "e", "ENDPOINTS", false, "Path where endpoint JSONs are located. Also accepts codex-deployment JSONs.")]
|
||||
public string EndpointsPath { get; set; } = "endpoints";
|
||||
|
||||
[Uniform("userdata", "u", "USERDATA", false, "Path where user data files will be saved.")]
|
||||
public string UserDataPath { get; set; } = "userdata";
|
||||
}
|
||||
}
|
||||
|
@ -13,6 +13,7 @@ namespace BiblioTech
|
||||
|
||||
public static Configuration Config { get; private set; } = null!;
|
||||
public static DeploymentsFilesMonitor DeploymentFilesMonitor { get; } = new DeploymentsFilesMonitor();
|
||||
public static UserRepo UserRepo { get; } = new UserRepo();
|
||||
|
||||
public static Task Main(string[] args)
|
||||
{
|
||||
|
@ -15,6 +15,8 @@ namespace BiblioTech.TokenCommands
|
||||
{
|
||||
}
|
||||
|
||||
// connect users to eth address!
|
||||
|
||||
public override string Name => "balance";
|
||||
public override string StartingMessage => "Fetching balance...";
|
||||
public override string Description => "Shows Eth and TestToken balance of an eth address.";
|
||||
|
128
Tools/BiblioTech/UserRepo.cs
Normal file
128
Tools/BiblioTech/UserRepo.cs
Normal file
@ -0,0 +1,128 @@
|
||||
using CodexContractsPlugin;
|
||||
using GethPlugin;
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace BiblioTech
|
||||
{
|
||||
public class UserRepo
|
||||
{
|
||||
private readonly object repoLock = new object();
|
||||
|
||||
public void AssociateUserWithAddress(ulong discordId, EthAddress address)
|
||||
{
|
||||
lock (repoLock)
|
||||
{
|
||||
SetUserAddress(discordId, address);
|
||||
}
|
||||
}
|
||||
|
||||
public void ClearUserAssociatedAddress(ulong discordId)
|
||||
{
|
||||
lock (repoLock)
|
||||
{
|
||||
SetUserAddress(discordId, null);
|
||||
}
|
||||
}
|
||||
|
||||
public void AddMintEventForUser(ulong discordId, EthAddress usedAddress, Ether eth, TestToken tokens)
|
||||
{
|
||||
lock (repoLock)
|
||||
{
|
||||
var user = GetOrCreate(discordId);
|
||||
user.MintEvents.Add(new UserMintEvent(DateTime.UtcNow, usedAddress, eth, tokens));
|
||||
SaveUser(user);
|
||||
}
|
||||
}
|
||||
|
||||
public EthAddress? GetCurrentAddressForUser(ulong discordId)
|
||||
{
|
||||
lock (repoLock)
|
||||
{
|
||||
return GetOrCreate(discordId).CurrentAddress;
|
||||
}
|
||||
}
|
||||
|
||||
private void SetUserAddress(ulong discordId, EthAddress? address)
|
||||
{
|
||||
var user = GetOrCreate(discordId);
|
||||
user.CurrentAddress = address;
|
||||
user.AssociateEvents.Add(new UserAssociateAddressEvent(DateTime.UtcNow, address));
|
||||
SaveUser(user);
|
||||
}
|
||||
|
||||
private User GetOrCreate(ulong discordId)
|
||||
{
|
||||
var filename = GetFilename(discordId);
|
||||
if (!File.Exists(filename))
|
||||
{
|
||||
return CreateAndSaveNewUser(discordId);
|
||||
}
|
||||
return JsonConvert.DeserializeObject<User>(File.ReadAllText(filename))!;
|
||||
}
|
||||
|
||||
private User CreateAndSaveNewUser(ulong discordId)
|
||||
{
|
||||
var newUser = new User(discordId, DateTime.UtcNow, null, new List<UserAssociateAddressEvent>(), new List<UserMintEvent>());
|
||||
SaveUser(newUser);
|
||||
return newUser;
|
||||
}
|
||||
|
||||
private void SaveUser(User user)
|
||||
{
|
||||
var filename = GetFilename(user.DiscordId);
|
||||
if (File.Exists(filename)) File.Delete(filename);
|
||||
File.WriteAllText(filename, JsonConvert.SerializeObject(user));
|
||||
}
|
||||
|
||||
private static string GetFilename(ulong discordId)
|
||||
{
|
||||
return Path.Combine(Program.Config.UserDataPath, discordId.ToString() + ".json");
|
||||
}
|
||||
}
|
||||
|
||||
public class User
|
||||
{
|
||||
public User(ulong discordId, DateTime createdUtc, EthAddress? currentAddress, List<UserAssociateAddressEvent> associateEvents, List<UserMintEvent> mintEvents)
|
||||
{
|
||||
DiscordId = discordId;
|
||||
CreatedUtc = createdUtc;
|
||||
CurrentAddress = currentAddress;
|
||||
AssociateEvents = associateEvents;
|
||||
MintEvents = mintEvents;
|
||||
}
|
||||
|
||||
public ulong DiscordId { get; }
|
||||
public DateTime CreatedUtc { get; }
|
||||
public EthAddress? CurrentAddress { get; set; }
|
||||
public List<UserAssociateAddressEvent> AssociateEvents { get; }
|
||||
public List<UserMintEvent> MintEvents { get; }
|
||||
}
|
||||
|
||||
public class UserAssociateAddressEvent
|
||||
{
|
||||
public UserAssociateAddressEvent(DateTime utc, EthAddress? newAddress)
|
||||
{
|
||||
Utc = utc;
|
||||
NewAddress = newAddress;
|
||||
}
|
||||
|
||||
public DateTime Utc { get; }
|
||||
public EthAddress? NewAddress { get; }
|
||||
}
|
||||
|
||||
public class UserMintEvent
|
||||
{
|
||||
public UserMintEvent(DateTime utc, EthAddress usedAddress, Ether ethReceived, TestToken testTokensMinted)
|
||||
{
|
||||
Utc = utc;
|
||||
UsedAddress = usedAddress;
|
||||
EthReceived = ethReceived;
|
||||
TestTokensMinted = testTokensMinted;
|
||||
}
|
||||
|
||||
public DateTime Utc { get; }
|
||||
public EthAddress UsedAddress { get; }
|
||||
public Ether EthReceived { get; }
|
||||
public TestToken TestTokensMinted { get; }
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user