use of com.hedera.hashgraph.sdk.TokenDeleteTransaction in project hedera-sdk-java by hashgraph.
the class TokenDeleteIntegrationTest method cannotDeleteTokenWhenTokenIDIsNotSet.
@Test
@DisplayName("Cannot delete token when token ID is not set")
void cannotDeleteTokenWhenTokenIDIsNotSet() throws Exception {
var testEnv = new IntegrationTestEnv(1).useThrowawayAccount();
assertThatExceptionOfType(PrecheckStatusException.class).isThrownBy(() -> {
new TokenDeleteTransaction().execute(testEnv.client).getReceipt(testEnv.client);
}).withMessageContaining(Status.INVALID_TOKEN_ID.toString());
testEnv.close();
}
use of com.hedera.hashgraph.sdk.TokenDeleteTransaction in project hedera-sdk-java by hashgraph.
the class TokenInfoIntegrationTest method canQueryTokenInfoWhenAllKeysAreDifferent.
@Test
@DisplayName("Can query token info when all keys are different")
void canQueryTokenInfoWhenAllKeysAreDifferent() throws Exception {
var testEnv = new IntegrationTestEnv(1).useThrowawayAccount();
var key1 = PrivateKey.generateED25519();
var key2 = PrivateKey.generateED25519();
var key3 = PrivateKey.generateED25519();
var key4 = PrivateKey.generateED25519();
var key5 = PrivateKey.generateED25519();
var response = new TokenCreateTransaction().setTokenName("ffff").setTokenSymbol("F").setDecimals(3).setInitialSupply(1000000).setTreasuryAccountId(testEnv.operatorId).setAdminKey(key1).setFreezeKey(key2).setWipeKey(key3).setKycKey(key4).setSupplyKey(key5).setFreezeDefault(false).freezeWith(testEnv.client).sign(key1).execute(testEnv.client);
var tokenId = Objects.requireNonNull(response.getReceipt(testEnv.client).tokenId);
var info = new TokenInfoQuery().setTokenId(tokenId).execute(testEnv.client);
assertThat(info.tokenId).isEqualTo(tokenId);
assertThat(info.name).isEqualTo("ffff");
assertThat(info.symbol).isEqualTo("F");
assertThat(info.decimals).isEqualTo(3);
assertThat(info.treasuryAccountId).isEqualTo(testEnv.operatorId);
assertThat(info.adminKey).isNotNull();
assertThat(info.freezeKey).isNotNull();
assertThat(info.wipeKey).isNotNull();
assertThat(info.kycKey).isNotNull();
assertThat(info.supplyKey).isNotNull();
assertThat(info.adminKey.toString()).isEqualTo(key1.getPublicKey().toString());
assertThat(info.freezeKey.toString()).isEqualTo(key2.getPublicKey().toString());
assertThat(info.wipeKey.toString()).isEqualTo(key3.getPublicKey().toString());
assertThat(info.kycKey.toString()).isEqualTo(key4.getPublicKey().toString());
assertThat(info.supplyKey.toString()).isEqualTo(key5.getPublicKey().toString());
assertThat(info.defaultFreezeStatus).isNotNull();
assertThat(info.defaultFreezeStatus).isFalse();
assertThat(info.defaultKycStatus).isNotNull();
assertThat(info.defaultKycStatus).isFalse();
assertThat(info.tokenType).isEqualTo(TokenType.FUNGIBLE_COMMON);
assertThat(info.supplyType).isEqualTo(TokenSupplyType.INFINITE);
new TokenDeleteTransaction().setTokenId(tokenId).freezeWith(testEnv.client).sign(key1).execute(testEnv.client).getReceipt(testEnv.client);
testEnv.close();
}
use of com.hedera.hashgraph.sdk.TokenDeleteTransaction in project hedera-sdk-java by hashgraph.
the class TokenDeleteIntegrationTest method canDeleteToken.
@Test
@DisplayName("Can delete token")
void canDeleteToken() throws Exception {
var testEnv = new IntegrationTestEnv(1).useThrowawayAccount();
var response = new TokenCreateTransaction().setTokenName("ffff").setTokenSymbol("F").setDecimals(3).setInitialSupply(1000000).setTreasuryAccountId(testEnv.operatorId).setAdminKey(testEnv.operatorKey).setFreezeKey(testEnv.operatorKey).setWipeKey(testEnv.operatorKey).setKycKey(testEnv.operatorKey).setSupplyKey(testEnv.operatorKey).setFreezeDefault(false).execute(testEnv.client);
var tokenId = Objects.requireNonNull(response.getReceipt(testEnv.client).tokenId);
new TokenDeleteTransaction().setTokenId(tokenId).execute(testEnv.client).getReceipt(testEnv.client);
testEnv.close();
}
use of com.hedera.hashgraph.sdk.TokenDeleteTransaction in project hedera-sdk-java by hashgraph.
the class TransferTokensExample method main.
public static void main(String[] args) throws Exception {
Client client = Client.forName(HEDERA_NETWORK);
// Defaults the operator account ID and key such that all generated transactions will be paid for
// by this account and be signed by this key
client.setOperator(OPERATOR_ID, OPERATOR_KEY);
// Generate a Ed25519 private, public key pair
PrivateKey key1 = PrivateKey.generateED25519();
PrivateKey key2 = PrivateKey.generateED25519();
System.out.println("private key = " + key1);
System.out.println("public key = " + key1.getPublicKey());
System.out.println("private key = " + key2);
System.out.println("public key = " + key2.getPublicKey());
@Var TransactionResponse response = new AccountCreateTransaction().setKey(key1.getPublicKey()).setInitialBalance(Hbar.fromTinybars(1000)).execute(client);
// This will wait for the receipt to become available
@Var TransactionReceipt receipt = response.getReceipt(client);
AccountId accountId1 = Objects.requireNonNull(receipt.accountId);
System.out.println("accountId1 = " + accountId1);
response = new AccountCreateTransaction().setKey(key2.getPublicKey()).setInitialBalance(Hbar.fromTinybars(1000)).execute(client);
// This will wait for the receipt to become available
receipt = response.getReceipt(client);
AccountId accountId2 = Objects.requireNonNull(receipt.accountId);
System.out.println("accountId2 = " + accountId1);
response = new TokenCreateTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setTokenName("ffff").setTokenSymbol("F").setDecimals(3).setInitialSupply(1000000).setTreasuryAccountId(OPERATOR_ID).setAdminKey(OPERATOR_KEY.getPublicKey()).setFreezeKey(OPERATOR_KEY.getPublicKey()).setWipeKey(OPERATOR_KEY.getPublicKey()).setKycKey(OPERATOR_KEY.getPublicKey()).setSupplyKey(OPERATOR_KEY.getPublicKey()).setFreezeDefault(false).execute(client);
TokenId tokenId = Objects.requireNonNull(response.getReceipt(client).tokenId);
System.out.println("token = " + tokenId);
new TokenAssociateTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setAccountId(accountId1).setTokenIds(Collections.singletonList(tokenId)).freezeWith(client).sign(OPERATOR_KEY).sign(key1).execute(client).getReceipt(client);
System.out.println("Associated account " + accountId1 + " with token " + tokenId);
new TokenAssociateTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setAccountId(accountId2).setTokenIds(Collections.singletonList(tokenId)).freezeWith(client).sign(OPERATOR_KEY).sign(key2).execute(client).getReceipt(client);
System.out.println("Associated account " + accountId2 + " with token " + tokenId);
new TokenGrantKycTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setAccountId(accountId1).setTokenId(tokenId).execute(client).getReceipt(client);
System.out.println("Granted KYC for account " + accountId1 + " on token " + tokenId);
new TokenGrantKycTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setAccountId(accountId2).setTokenId(tokenId).execute(client).getReceipt(client);
System.out.println("Granted KYC for account " + accountId2 + " on token " + tokenId);
new TransferTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).addTokenTransfer(tokenId, OPERATOR_ID, -10).addTokenTransfer(tokenId, accountId1, 10).execute(client).getReceipt(client);
System.out.println("Sent 10 tokens from account " + OPERATOR_ID + " to account " + accountId1 + " on token " + tokenId);
new TransferTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).addTokenTransfer(tokenId, accountId1, -10).addTokenTransfer(tokenId, accountId2, 10).freezeWith(client).sign(key1).execute(client).getReceipt(client);
System.out.println("Sent 10 tokens from account " + accountId1 + " to account " + accountId2 + " on token " + tokenId);
new TransferTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).addTokenTransfer(tokenId, accountId2, -10).addTokenTransfer(tokenId, accountId1, 10).freezeWith(client).sign(key2).execute(client).getReceipt(client);
System.out.println("Sent 10 tokens from account " + accountId2 + " to account " + accountId1 + " on token " + tokenId);
new TokenWipeTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setTokenId(tokenId).setAccountId(accountId1).setAmount(10).execute(client).getReceipt(client);
System.out.println("Wiped balance of account " + accountId1);
new TokenDeleteTransaction().setNodeAccountIds(Collections.singletonList(response.nodeId)).setTokenId(tokenId).execute(client).getReceipt(client);
System.out.println("Deleted token " + tokenId);
new AccountDeleteTransaction().setAccountId(accountId1).setTransferAccountId(OPERATOR_ID).freezeWith(client).sign(OPERATOR_KEY).sign(key1).execute(client).getReceipt(client);
System.out.println("Deleted accountId1 " + accountId1);
new AccountDeleteTransaction().setAccountId(accountId2).setTransferAccountId(OPERATOR_ID).freezeWith(client).sign(OPERATOR_KEY).sign(key2).execute(client).getReceipt(client);
System.out.println("Deleted accountId2" + accountId2);
}
use of com.hedera.hashgraph.sdk.TokenDeleteTransaction in project hedera-sdk-java by hashgraph.
the class AutomaticAssociationTest method autoAssociateTest.
@Test
@DisplayName("Tokens automatically become associated")
void autoAssociateTest() throws Exception {
var testEnv = new IntegrationTestEnv(1).useThrowawayAccount();
var key = PrivateKey.generateED25519();
var accountId = new AccountCreateTransaction().setKey(key).setInitialBalance(new Hbar(10)).setMaxAutomaticTokenAssociations(1).execute(testEnv.client).getReceipt(testEnv.client).accountId;
Objects.requireNonNull(accountId);
var accountInfo1 = new AccountInfoQuery().setAccountId(accountId).execute(testEnv.client);
assertThat(accountInfo1.maxAutomaticTokenAssociations).isEqualTo(1);
assertThat(accountInfo1.tokenRelationships.size()).isEqualTo(0);
var tokenId1 = new TokenCreateTransaction().setTreasuryAccountId(testEnv.operatorId).setTokenName("Test Token").setTokenSymbol("T").setAdminKey(testEnv.operatorKey).setInitialSupply(1).execute(testEnv.client).getReceipt(testEnv.client).tokenId;
var tokenId2 = new TokenCreateTransaction().setTreasuryAccountId(testEnv.operatorId).setTokenName("Test Token").setTokenSymbol("T").setAdminKey(testEnv.operatorKey).setInitialSupply(1).execute(testEnv.client).getReceipt(testEnv.client).tokenId;
Objects.requireNonNull(tokenId1);
Objects.requireNonNull(tokenId2);
var transferResponse1 = new TransferTransaction().addTokenTransfer(tokenId1, testEnv.operatorId, -1).addTokenTransfer(tokenId1, accountId, 1).execute(testEnv.client);
transferResponse1.getReceipt(testEnv.client);
var transferRecord = transferResponse1.getRecord(testEnv.client);
assertThat(transferRecord.automaticTokenAssociations.size()).isEqualTo(1);
assertThat(transferRecord.automaticTokenAssociations.get(0).accountId).isEqualTo(accountId);
assertThat(transferRecord.automaticTokenAssociations.get(0).tokenId).isEqualTo(tokenId1);
var accountInfo2 = new AccountInfoQuery().setAccountId(accountId).execute(testEnv.client);
assertThat(accountInfo2.tokenRelationships.size()).isEqualTo(1);
assertThat(accountInfo2.tokenRelationships.get(tokenId1).automaticAssociation).isTrue();
assertThatExceptionOfType(Exception.class).isThrownBy(() -> {
new TransferTransaction().addTokenTransfer(tokenId2, testEnv.operatorId, -1).addTokenTransfer(tokenId2, accountId, 1).execute(testEnv.client).getReceipt(testEnv.client);
}).withMessageContaining("NO_REMAINING_AUTOMATIC_ASSOCIATIONS");
new AccountUpdateTransaction().setAccountId(accountId).setMaxAutomaticTokenAssociations(2).freezeWith(testEnv.client).sign(key).execute(testEnv.client).getReceipt(testEnv.client);
var accountInfo3 = new AccountInfoQuery().setAccountId(accountId).execute(testEnv.client);
assertThat(accountInfo3.maxAutomaticTokenAssociations).isEqualTo(2);
new TokenDeleteTransaction().setTokenId(tokenId1).execute(testEnv.client).getReceipt(testEnv.client);
new TokenDeleteTransaction().setTokenId(tokenId2).execute(testEnv.client).getReceipt(testEnv.client);
testEnv.close(accountId, key);
}
Aggregations