UNPKG

@fruitsjs/core

Version:

Principal package with functions and models for building Fruits Eco-Blockchain applications.

39 lines (32 loc) 1.6 kB
import {ChainService} from '../../../service/chainService'; import {TransactionId} from '../../../typings/transactionId'; import {TransactionResponse} from '../../../typings/transactionResponse'; import {DefaultDeadline} from '../../../constants'; import {signAndBroadcastTransaction} from './signAndBroadcastTransaction'; import {createParametersFromAttachment} from '../../../internal/createParametersFromAttachment'; import {CancelSubscriptionArgs} from '../../../typings/args/cancelSubscriptionArgs'; /** * Use with [[ApiComposer]] and belongs to [[TransactionApi]]. * * See details at [[TransactionApi.cancelSubscription]] * @module core.api.factories */ export const cancelSubscription = (service: ChainService): (args: CancelSubscriptionArgs) => Promise<TransactionId> => async (args: CancelSubscriptionArgs): Promise<TransactionId> => { let parameters = { subscription: args.subscriptionId, publicKey: args.senderPublicKey, feeNQT: args.feePlanck, deadline: args.deadline || DefaultDeadline }; if (args.attachment) { parameters = createParametersFromAttachment(args.attachment, parameters); } const {unsignedTransactionBytes: unsignedHexMessage} = await service.send<TransactionResponse>('subscriptionCancel', parameters); return signAndBroadcastTransaction(service)({ senderPublicKey: args.senderPublicKey, senderPrivateKey: args.senderPrivateKey, unsignedHexMessage }); };