2021-07-22 07:18:37 -07:00
|
|
|
#!/usr/bin/env pyston3
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import logging
|
2021-07-22 07:58:00 -07:00
|
|
|
from mango.accountinfo import AccountInfo
|
2021-07-22 07:18:37 -07:00
|
|
|
import os
|
|
|
|
import os.path
|
|
|
|
import sys
|
2021-07-22 07:58:00 -07:00
|
|
|
import typing
|
2021-07-22 07:18:37 -07:00
|
|
|
|
|
|
|
from solana.publickey import PublicKey
|
|
|
|
|
|
|
|
sys.path.insert(0, os.path.abspath(
|
|
|
|
os.path.join(os.path.dirname(__file__), "..")))
|
|
|
|
import mango # nopep8
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(description="Shows the on-chain data of a particular account.")
|
|
|
|
mango.Context.add_command_line_parameters(parser)
|
|
|
|
parser.add_argument("--address", type=PublicKey, required=True, help="Address of the Solana account to watch")
|
2021-07-22 07:58:00 -07:00
|
|
|
parser.add_argument("--account-type", type=str, default="AccountInfo",
|
2021-07-22 07:18:37 -07:00
|
|
|
help="Underlying object type of the data in the AccountInfo")
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
logging.getLogger().setLevel(args.log_level)
|
|
|
|
logging.warning(mango.WARNING_DISCLAIMER_TEXT)
|
|
|
|
|
|
|
|
context = mango.Context.from_command_line_parameters(args)
|
2021-07-22 07:58:00 -07:00
|
|
|
converter: typing.Callable[[AccountInfo], typing.Any] = lambda account_info: account_info
|
|
|
|
if args.account_type.upper() != "ACCOUNTINFO":
|
|
|
|
converter = mango.build_account_info_converter(context, args.account_type)
|
2021-07-22 07:18:37 -07:00
|
|
|
|
2021-07-22 07:58:00 -07:00
|
|
|
account_info: typing.Optional[mango.AccountInfo] = mango.AccountInfo.load(context, args.address)
|
2021-07-22 07:18:37 -07:00
|
|
|
if account_info is None:
|
|
|
|
raise Exception(f"No account found at address: {args.address}")
|
|
|
|
|
|
|
|
print(converter(account_info))
|