2023-10-24 15:25:45 +02:00
|
|
|
|
using BiblioTech.Options;
|
|
|
|
|
using CodexContractsPlugin;
|
2023-10-20 10:14:56 +02:00
|
|
|
|
using GethPlugin;
|
|
|
|
|
|
2023-10-22 10:38:46 +02:00
|
|
|
|
namespace BiblioTech.Commands
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-11-02 12:30:48 +01:00
|
|
|
|
public class MintCommand : BaseGethCommand
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-10-22 10:10:52 +02:00
|
|
|
|
private readonly UserOption optionalUser = new UserOption(
|
|
|
|
|
description: "If set, mint tokens for this user. (Optional, admin-only)",
|
2023-10-22 11:10:45 +02:00
|
|
|
|
isRequired: false);
|
|
|
|
|
private readonly UserAssociateCommand userAssociateCommand;
|
2023-10-20 10:14:56 +02:00
|
|
|
|
|
2023-12-11 11:01:12 +01:00
|
|
|
|
public MintCommand(UserAssociateCommand userAssociateCommand)
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-10-22 11:10:45 +02:00
|
|
|
|
this.userAssociateCommand = userAssociateCommand;
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override string Name => "mint";
|
2023-11-02 12:30:48 +01:00
|
|
|
|
public override string StartingMessage => RandomBusyMessage.Get();
|
2023-10-22 10:10:52 +02:00
|
|
|
|
public override string Description => "Mint some TestTokens and send some Eth to the user if their balance is low.";
|
|
|
|
|
public override CommandOption[] Options => new[] { optionalUser };
|
2023-10-20 10:14:56 +02:00
|
|
|
|
|
2023-10-24 15:25:45 +02:00
|
|
|
|
protected override async Task Execute(CommandContext context, IGethNode gethNode, ICodexContracts contracts)
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-10-25 11:25:27 +02:00
|
|
|
|
var userId = GetUserFromCommand(optionalUser, context);
|
2023-10-22 10:10:52 +02:00
|
|
|
|
var addr = Program.UserRepo.GetCurrentAddressForUser(userId);
|
2023-10-22 11:10:45 +02:00
|
|
|
|
if (addr == null)
|
|
|
|
|
{
|
2023-10-25 10:54:26 +02:00
|
|
|
|
await context.Followup($"No address has been set for this user. Please use '/{userAssociateCommand.Name}' to set it first.");
|
2024-09-30 10:59:22 +02:00
|
|
|
|
await Program.AdminChecker.SendInAdminChannel($"User {Mention(userId)} used '/{Name}' but address has not been set.");
|
2023-10-22 11:10:45 +02:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var report = new List<string>();
|
|
|
|
|
|
2024-04-08 13:36:55 +02:00
|
|
|
|
Transaction<Ether>? sentEth = null;
|
|
|
|
|
Transaction<TestToken>? mintedTokens = null;
|
|
|
|
|
|
|
|
|
|
await Task.Run(() =>
|
|
|
|
|
{
|
|
|
|
|
sentEth = ProcessEth(gethNode, addr, report);
|
|
|
|
|
mintedTokens = ProcessTokens(contracts, addr, report);
|
|
|
|
|
});
|
2023-10-20 10:14:56 +02:00
|
|
|
|
|
2024-09-30 10:59:22 +02:00
|
|
|
|
var reportLine = string.Join(Environment.NewLine, report);
|
2023-10-22 11:10:45 +02:00
|
|
|
|
Program.UserRepo.AddMintEventForUser(userId, addr, sentEth, mintedTokens);
|
2024-09-30 10:59:22 +02:00
|
|
|
|
await Program.AdminChecker.SendInAdminChannel($"User {Mention(userId)} used '/{Name}' successfully. ({reportLine})");
|
2023-10-20 10:14:56 +02:00
|
|
|
|
|
2024-09-30 10:59:22 +02:00
|
|
|
|
await context.Followup(reportLine);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string Format<T>(Transaction<T>? transaction)
|
|
|
|
|
{
|
|
|
|
|
if (transaction == null) return "-";
|
|
|
|
|
return transaction.ToString();
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-12-15 11:09:15 +01:00
|
|
|
|
private Transaction<TestToken>? ProcessTokens(ICodexContracts contracts, EthAddress addr, List<string> report)
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-10-30 13:30:14 +01:00
|
|
|
|
if (ShouldMintTestTokens(contracts, addr))
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2024-05-22 11:06:34 +02:00
|
|
|
|
var tokens = Program.Config.MintTT.TstWei();
|
2024-03-29 11:24:11 +01:00
|
|
|
|
var transaction = contracts.MintTestTokens(addr, tokens);
|
|
|
|
|
report.Add($"Minted {tokens} {FormatTransactionLink(transaction)}");
|
|
|
|
|
return new Transaction<TestToken>(tokens, transaction);
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
2023-10-22 11:10:45 +02:00
|
|
|
|
|
2023-12-15 11:02:06 +01:00
|
|
|
|
report.Add("TestToken balance over threshold. (No TestTokens minted.)");
|
2023-12-15 11:09:15 +01:00
|
|
|
|
return null;
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
|
|
|
|
|
2023-12-15 11:09:15 +01:00
|
|
|
|
private Transaction<Ether>? ProcessEth(IGethNode gethNode, EthAddress addr, List<string> report)
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2023-10-22 11:10:45 +02:00
|
|
|
|
if (ShouldSendEth(gethNode, addr))
|
2023-10-20 10:14:56 +02:00
|
|
|
|
{
|
2024-03-29 11:24:11 +01:00
|
|
|
|
var eth = Program.Config.SendEth.Eth();
|
|
|
|
|
var transaction = gethNode.SendEth(addr, eth);
|
|
|
|
|
report.Add($"Sent {eth} {FormatTransactionLink(transaction)}");
|
|
|
|
|
return new Transaction<Ether>(eth, transaction);
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
2023-12-15 11:02:06 +01:00
|
|
|
|
report.Add("Eth balance is over threshold. (No Eth sent.)");
|
2023-12-15 11:09:15 +01:00
|
|
|
|
return null;
|
2023-10-22 11:10:45 +02:00
|
|
|
|
}
|
2023-10-20 10:14:56 +02:00
|
|
|
|
|
2023-10-30 13:30:14 +01:00
|
|
|
|
private bool ShouldMintTestTokens(ICodexContracts contracts, EthAddress addr)
|
2023-10-22 11:10:45 +02:00
|
|
|
|
{
|
2023-10-30 13:30:14 +01:00
|
|
|
|
var testTokens = contracts.GetTestTokenBalance(addr);
|
2024-05-22 11:06:34 +02:00
|
|
|
|
return testTokens < Program.Config.MintTT.TstWei();
|
2023-10-22 11:10:45 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool ShouldSendEth(IGethNode gethNode, EthAddress addr)
|
|
|
|
|
{
|
|
|
|
|
var eth = gethNode.GetEthBalance(addr);
|
2024-03-29 11:24:11 +01:00
|
|
|
|
return eth.Eth < Program.Config.SendEth;
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
2023-12-15 11:02:06 +01:00
|
|
|
|
|
|
|
|
|
private string FormatTransactionLink(string transaction)
|
|
|
|
|
{
|
2023-12-18 11:27:28 +01:00
|
|
|
|
var url = $"https://explorer.testnet.codex.storage/tx/{transaction}";
|
2023-12-18 16:38:16 +02:00
|
|
|
|
return $"- [View on block explorer](<{url}>){Environment.NewLine}Transaction ID - `{transaction}`";
|
2023-12-15 11:02:06 +01:00
|
|
|
|
}
|
2023-10-20 10:14:56 +02:00
|
|
|
|
}
|
|
|
|
|
}
|