Enable KYC account flag
Grants KYC to the Hedera accounts for the given Hedera token. This transaction must be signed by the token's KYC Key.
- If the provided account is not found, the transaction will resolve to INVALID_ACCOUNT_ID.
- If the provided account has been deleted, the transaction will resolve to ACCOUNT_DELETED.
- If the provided token is not found, the transaction will resolve to INVALID_TOKEN_ID.
- If the provided token has been deleted, the transaction will resolve to TOKEN_WAS_DELETED.
- If an Association between the provided token and account is not found, the transaction will resolve to TOKEN_NOT_ASSOCIATED_TO_ACCOUNT.
- If no KYC Key is defined, the transaction will resolve to TOKEN_HAS_NO_KYC_KEY.
- Once executed the Account is marked as KYC Granted.
Transaction Signing Requirements
- KYC key
- Transaction fee payer account key
Transaction Fees
Constructor | Description |
---|---|
new TokenGrantKycTransaction() | Initializes the TokenGrantKycTransaction object |
new TokenGrantKycTransaction()
V1
Method | Type | Description | Requirement |
---|---|---|---|
setTokenId(<tokenId>) | TokenId | The token for this account to have passed KYC | Required |
setAccountId(<accountId>) | AccountId | The account for this token to have passed KYC | Required |
Java
//Enable KYC flag on account
TokenGrantKycTransaction transaction = new TokenGrantKycTransaction()
.setTokenId(newTokenId)
.setAccountId(newAccountId);
//Build the unsigned transaction, sign with the kyc private key of the token, submit the transaction to a Hedera network
TransactionId transactionId = transaction.build(client).sign(kycKey).execute(client);
//Request the receipt of the transaction
TransactionReceipt getReceipt = transactionId.getReceipt(client);
//Obtain the transaction consensus status
Status transactionStatus = getReceipt.status;
System.out.println("The transaction consensus status is " +transactionStatus);
//Version: 1.2.2
JavaScript
//Enable KYC flag on account
const transaction = new TokenGrantKycTransaction()
.setTokenId(newTokenId)
.setAccountId(newAccountId);
//Build the unsigned transaction, sign with the kyc private key of the token, submit the transaction to a Hedera network
const transactionId = await transaction.build(client).sign(kycKey).execute(client);
//Request the receipt of the transaction
const getReceipt = await transactionId.getReceipt(client);
//Obtain the transaction consensus status
const transactionStatus = getReceipt.status;
console.log("The transaction consensus status is " +transactionStatus);
//Version 1.4.2
Last modified 3mo ago