diff --git a/CHANGELOG.md b/CHANGELOG.md index 8474e302f..cd9fe3848 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,9 @@ As this project is pre 1.0, breaking changes may happen for minor version bumps. A breaking change will get clearly notified in this log. +## 0.21.2 +- Fix the decoding of `balanceId` in `org.stellar.sdk.ClaimClaimableBalanceOperation`. ([#310](https://github.com/stellar/java-stellar-sdk/pull/310)) + ## 0.21.1 - Fix NullPointerException in `org.stellar.sdk.responses.operations.RevokeSponsorshipOperationResponse` accessor methods. diff --git a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java index 4438da0e0..ce291a9bc 100644 --- a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java @@ -4,6 +4,9 @@ import com.google.common.io.BaseEncoding; import org.stellar.sdk.xdr.*; +import java.io.ByteArrayInputStream; +import java.io.IOException; + import static com.google.common.base.Preconditions.checkNotNull; public class ClaimClaimableBalanceOperation extends Operation { @@ -22,14 +25,16 @@ public String getBalanceId() { org.stellar.sdk.xdr.Operation.OperationBody toOperationBody() { ClaimClaimableBalanceOp op = new ClaimClaimableBalanceOp(); - ClaimableBalanceID id = new ClaimableBalanceID(); - id.setDiscriminant(ClaimableBalanceIDType.CLAIMABLE_BALANCE_ID_TYPE_V0); - Hash hash = new Hash(); - hash.setHash(BaseEncoding.base16().lowerCase().decode(balanceId.toLowerCase())); - id.setV0(hash); + byte[] balanceIdBytes = BaseEncoding.base16().lowerCase().decode(balanceId.toLowerCase()); + XdrDataInputStream balanceIdXdrDataInputStream = new XdrDataInputStream(new ByteArrayInputStream(balanceIdBytes)); + ClaimableBalanceID id; + try { + id = ClaimableBalanceID.decode(balanceIdXdrDataInputStream); + } catch (IOException e) { + throw new IllegalArgumentException("invalid balanceId: " + balanceId, e); + } op.setBalanceID(id); - org.stellar.sdk.xdr.Operation.OperationBody body = new org.stellar.sdk.xdr.Operation.OperationBody(); body.setDiscriminant(OperationType.CLAIM_CLAIMABLE_BALANCE); body.setClaimClaimableBalanceOp(op);