43 lines
1.5 KiB
C#
43 lines
1.5 KiB
C#
using GethPlugin;
|
|
using Nethereum.Util;
|
|
|
|
namespace BiblioTech.Options
|
|
{
|
|
public class EthAddressOption : CommandOption
|
|
{
|
|
public EthAddressOption()
|
|
: base(name: "ethaddress",
|
|
description: "Ethereum address starting with '0x'.",
|
|
type: Discord.ApplicationCommandOptionType.String,
|
|
isRequired: true)
|
|
{
|
|
}
|
|
|
|
public async Task<EthAddress?> Parse(CommandContext context)
|
|
{
|
|
var ethOptionData = context.Options.SingleOrDefault(o => o.Name == Name);
|
|
if (ethOptionData == null)
|
|
{
|
|
await context.Command.FollowupAsync("EthAddress option not received.");
|
|
return null;
|
|
}
|
|
var ethAddressStr = ethOptionData.Value as string;
|
|
if (string.IsNullOrEmpty(ethAddressStr))
|
|
{
|
|
await context.Command.FollowupAsync("EthAddress is null or empty.");
|
|
return null;
|
|
}
|
|
|
|
if (!AddressUtil.Current.IsValidAddressLength(ethAddressStr) ||
|
|
!AddressUtil.Current.IsValidEthereumAddressHexFormat(ethAddressStr))
|
|
// !AddressUtil.Current.IsChecksumAddress(ethAddressStr)) - this might make a good option later, but for now it might just annoy users.
|
|
{
|
|
await context.Command.FollowupAsync("EthAddress is not valid.");
|
|
return null;
|
|
}
|
|
|
|
return new EthAddress(ethAddressStr);
|
|
}
|
|
}
|
|
}
|