@hashgraph/hedera-cli
Version:
CLI tool to manage and setup developer environments for Hedera Hashgraph.
52 lines (46 loc) • 1.77 kB
text/typescript
import stateUtils from '../../utils/state';
import telemetryUtils from '../../utils/telemetry';
import dynamicVariablesUtils from '../../utils/dynamicVariables';
import { Logger } from '../../utils/logger';
import type { Command } from '../../../types';
import api from '../../api';
const logger = Logger.getInstance();
export default (program: any) => {
program
.command('view')
.hook('preAction', async (thisCommand: Command) => {
const command = [
thisCommand.parent.action().name(),
...thisCommand.parent.args,
];
if (stateUtils.isTelemetryEnabled()) {
await telemetryUtils.recordCommand(command.join(' '));
}
})
.description(
'View the detials of an account by accound ID. The account can be in the state or external.',
)
.requiredOption('-i, --id <id>', 'Account ID')
.action(async (options: ViewAccountOptions) => {
options = dynamicVariablesUtils.replaceOptions(options);
logger.verbose(`Viewing account ${options.id} details`);
try {
const response = await api.account.getAccountInfo(options.id);
logger.log(`Account: ${response.data.account}`);
logger.log(`Balance Tinybars: ${response.data.balance.balance}`);
logger.log(`Deleted: ${response.data.deleted}`);
logger.log(`EVM Address: ${response.data.evm_address}`);
logger.log(
`Key type: ${response.data.key._type} - Key: ${response.data.key.key}`,
);
logger.log(
`Max automatic token associations: ${response.data.max_automatic_token_associations}`,
);
} catch (error) {
logger.error('Failed to get account info:', error as object);
}
});
};
interface ViewAccountOptions {
id: string;
}