@fruitsjs/core
Version:
Principal package with functions and models for building Fruits Eco-Blockchain applications.
34 lines (29 loc) • 1.35 kB
text/typescript
import {ChainService} from '../../../service/chainService';
import {TransactionId} from '../../../typings/transactionId';
import {TransactionResponse} from '../../../typings/transactionResponse';
import {signAndBroadcastTransaction} from '../transaction/signAndBroadcastTransaction';
import {DefaultDeadline} from '../../../constants';
import {SetAccountInfoArgs} from '../../../typings/args/setAccountInfoArgs';
/**
* Use with [[ApiComposer]] and belongs to [[AccountApi]].
*
* See details at [[AccountApi.setAccountInfo]]
* @module core.api.factories
*/
export const setAccountInfo = (service: ChainService):
(args: SetAccountInfoArgs) => Promise<TransactionId> =>
async (args: SetAccountInfoArgs): Promise<TransactionId> => {
const parameters = {
name: args.name,
description: args.description,
deadline: args.deadline,
feeNQT: args.feePlanck,
publicKey: args.senderPublicKey
};
const {unsignedTransactionBytes: unsignedHexMessage} = await service.send<TransactionResponse>('setAccountInfo', parameters);
return signAndBroadcastTransaction(service)({
senderPrivateKey: args.senderPrivateKey,
senderPublicKey: args.senderPublicKey,
unsignedHexMessage
});
};