From 6c6ae0993b4ab727b7b171297897592eb1ab2006 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 10:32:09 +0800 Subject: [PATCH 01/20] Use `lombok.NonNull` instead of `com.google.common.base.Preconditions.checkNotNull` for checking. --- .../org/stellar/sdk/AbstractTransaction.java | 16 +++---- src/main/java/org/stellar/sdk/Account.java | 9 ++-- .../stellar/sdk/AccountMergeOperation.java | 7 ++- .../org/stellar/sdk/AllowTrustOperation.java | 12 +++-- .../stellar/sdk/AssetTypeCreditAlphaNum.java | 7 +-- ...eginSponsoringFutureReservesOperation.java | 8 ++-- .../stellar/sdk/BumpSequenceOperation.java | 7 ++- .../org/stellar/sdk/ChangeTrustAsset.java | 5 +- .../org/stellar/sdk/ChangeTrustOperation.java | 19 ++++---- .../sdk/ClaimClaimableBalanceOperation.java | 11 ++--- .../ClawbackClaimableBalanceOperation.java | 7 ++- .../org/stellar/sdk/ClawbackOperation.java | 12 ++--- .../stellar/sdk/CreateAccountOperation.java | 9 ++-- .../sdk/CreateClaimableBalanceOperation.java | 16 +++---- .../sdk/CreatePassiveSellOfferOperation.java | 34 ++++++++------ .../EndSponsoringFutureReservesOperation.java | 7 ++- .../org/stellar/sdk/FeeBumpTransaction.java | 32 ++++++------- src/main/java/org/stellar/sdk/KeyPair.java | 6 +-- ...iquidityPoolConstantProductParameters.java | 8 +--- .../sdk/LiquidityPoolDepositOperation.java | 29 ++++++------ .../LiquidityPoolShareChangeTrustAsset.java | 6 +-- .../sdk/LiquidityPoolShareTrustLineAsset.java | 9 ++-- .../sdk/LiquidityPoolWithdrawOperation.java | 20 ++++---- .../stellar/sdk/ManageBuyOfferOperation.java | 35 ++++++++------ .../org/stellar/sdk/ManageDataOperation.java | 15 +++--- .../stellar/sdk/ManageSellOfferOperation.java | 35 ++++++++------ .../org/stellar/sdk/MemoHashAbstract.java | 5 +- src/main/java/org/stellar/sdk/MemoText.java | 13 +++--- src/main/java/org/stellar/sdk/Network.java | 7 ++- src/main/java/org/stellar/sdk/Operation.java | 6 +-- .../PathPaymentStrictReceiveOperation.java | 46 ++++++++++--------- .../sdk/PathPaymentStrictSendOperation.java | 45 +++++++++--------- .../org/stellar/sdk/PaymentOperation.java | 12 ++--- src/main/java/org/stellar/sdk/Price.java | 6 +-- .../RevokeAccountSponsorshipOperation.java | 8 ++-- ...eClaimableBalanceSponsorshipOperation.java | 7 ++- .../sdk/RevokeDataSponsorshipOperation.java | 7 ++- .../sdk/RevokeOfferSponsorshipOperation.java | 7 ++- .../sdk/RevokeSignerSponsorshipOperation.java | 8 ++-- .../RevokeTrustlineSponsorshipOperation.java | 8 ++-- .../org/stellar/sdk/SetOptionsOperation.java | 7 +-- .../org/stellar/sdk/SignedPayloadSigner.java | 11 ++--- src/main/java/org/stellar/sdk/Signer.java | 15 ++---- .../java/org/stellar/sdk/Transaction.java | 10 ++-- .../org/stellar/sdk/TransactionBuilder.java | 34 ++++++-------- .../java/org/stellar/sdk/TrustLineAsset.java | 5 +- .../sdk/requests/EffectsRequestBuilder.java | 9 ++-- .../sdk/requests/OffersRequestBuilder.java | 6 +-- .../requests/OperationsRequestBuilder.java | 12 ++--- .../sdk/requests/PaymentsRequestBuilder.java | 9 ++-- .../sdk/requests/TradesRequestBuilder.java | 9 ++-- .../requests/TransactionsRequestBuilder.java | 9 ++-- .../sdk/responses/AccountResponse.java | 27 ++++++----- .../sdk/responses/LiquidityPoolResponse.java | 15 +++--- .../sdk/responses/OrderBookResponse.java | 11 ++--- .../java/org/stellar/sdk/responses/Page.java | 15 +++--- .../sdk/responses/TransactionResponse.java | 6 +-- .../stellar/sdk/TransactionBuilderTest.java | 2 +- 58 files changed, 365 insertions(+), 413 deletions(-) diff --git a/src/main/java/org/stellar/sdk/AbstractTransaction.java b/src/main/java/org/stellar/sdk/AbstractTransaction.java index 50e908122..8be33931d 100644 --- a/src/main/java/org/stellar/sdk/AbstractTransaction.java +++ b/src/main/java/org/stellar/sdk/AbstractTransaction.java @@ -1,13 +1,12 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.collect.ImmutableList; import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import lombok.NonNull; import org.stellar.sdk.xdr.DecoratedSignature; import org.stellar.sdk.xdr.Hash; import org.stellar.sdk.xdr.SignatureHint; @@ -15,14 +14,15 @@ import org.stellar.sdk.xdr.TransactionSignaturePayload; public abstract class AbstractTransaction { + protected final Network mNetwork; protected final AccountConverter accountConverter; protected List mSignatures; public static final int MIN_BASE_FEE = 100; - AbstractTransaction(AccountConverter accountConverter, Network network) { - this.accountConverter = checkNotNull(accountConverter, "accountConverter cannot be null"); - this.mNetwork = checkNotNull(network, "network cannot be null"); + AbstractTransaction(@NonNull AccountConverter accountConverter, @NonNull Network network) { + this.accountConverter = accountConverter; + this.mNetwork = network; this.mSignatures = new ArrayList(); } @@ -31,8 +31,7 @@ public abstract class AbstractTransaction { * * @param signer {@link KeyPair} object representing a signer */ - public void sign(KeyPair signer) { - checkNotNull(signer, "signer cannot be null"); + public void sign(@NonNull KeyPair signer) { byte[] txHash = this.hash(); mSignatures.add(signer.signDecorated(txHash)); } @@ -42,8 +41,7 @@ public void sign(KeyPair signer) { * * @param preimage the sha256 hash of preimage should be equal to signer hash */ - public void sign(byte[] preimage) { - checkNotNull(preimage, "preimage cannot be null"); + public void sign(byte @NonNull [] preimage) { org.stellar.sdk.xdr.Signature signature = new org.stellar.sdk.xdr.Signature(); signature.setSignature(preimage); diff --git a/src/main/java/org/stellar/sdk/Account.java b/src/main/java/org/stellar/sdk/Account.java index 8d1f77bb7..338b5db3c 100644 --- a/src/main/java/org/stellar/sdk/Account.java +++ b/src/main/java/org/stellar/sdk/Account.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; /** * Represents an account in Stellar network with it's sequence number. Account object is required to @@ -21,9 +20,9 @@ public class Account implements TransactionBuilderAccount { * @param sequenceNumber Current sequence number of the account (can be obtained using * java-stellar-sdk or horizon server) */ - public Account(String accountId, Long sequenceNumber) { - mAccountId = checkNotNull(accountId, "accountId cannot be null"); - mSequenceNumber = checkNotNull(sequenceNumber, "sequenceNumber cannot be null"); + public Account(@NonNull String accountId, @NonNull Long sequenceNumber) { + mAccountId = accountId; + mSequenceNumber = sequenceNumber; } @Override diff --git a/src/main/java/org/stellar/sdk/AccountMergeOperation.java b/src/main/java/org/stellar/sdk/AccountMergeOperation.java index 1f2a9b9a9..53409579d 100644 --- a/src/main/java/org/stellar/sdk/AccountMergeOperation.java +++ b/src/main/java/org/stellar/sdk/AccountMergeOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.Operation.OperationBody; import org.stellar.sdk.xdr.OperationType; @@ -17,8 +16,8 @@ public class AccountMergeOperation extends Operation { private final String destination; - private AccountMergeOperation(String destination) { - this.destination = checkNotNull(destination, "destination cannot be null"); + private AccountMergeOperation(@NonNull String destination) { + this.destination = destination; } /** The account that receives the remaining XLM balance of the source account. */ diff --git a/src/main/java/org/stellar/sdk/AllowTrustOperation.java b/src/main/java/org/stellar/sdk/AllowTrustOperation.java index 2ef0e823c..e1a79f318 100644 --- a/src/main/java/org/stellar/sdk/AllowTrustOperation.java +++ b/src/main/java/org/stellar/sdk/AllowTrustOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -21,9 +20,12 @@ public class AllowTrustOperation extends Operation { private final boolean authorizeToMaintainLiabilities; private AllowTrustOperation( - String trustor, String assetCode, boolean authorize, boolean authorizeToMaintainLiabilities) { - this.trustor = checkNotNull(trustor, "trustor cannot be null"); - this.assetCode = checkNotNull(assetCode, "assetCode cannot be null"); + @NonNull String trustor, + @NonNull String assetCode, + boolean authorize, + boolean authorizeToMaintainLiabilities) { + this.trustor = trustor; + this.assetCode = assetCode; this.authorize = authorize; this.authorizeToMaintainLiabilities = authorizeToMaintainLiabilities; } diff --git a/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java b/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java index a8b126586..cee0e8333 100644 --- a/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java +++ b/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; /** * Base class for AssetTypeCreditAlphaNum4 and AssetTypeCreditAlphaNum12 subclasses. @@ -13,9 +12,7 @@ public abstract class AssetTypeCreditAlphaNum extends Asset { protected final String mCode; protected final String mIssuer; - public AssetTypeCreditAlphaNum(String code, String issuer) { - checkNotNull(code, "code cannot be null"); - checkNotNull(issuer, "issuer cannot be null"); + public AssetTypeCreditAlphaNum(@NonNull String code, @NonNull String issuer) { mCode = code; mIssuer = issuer; } diff --git a/src/main/java/org/stellar/sdk/BeginSponsoringFutureReservesOperation.java b/src/main/java/org/stellar/sdk/BeginSponsoringFutureReservesOperation.java index f0c85db43..ada777a06 100644 --- a/src/main/java/org/stellar/sdk/BeginSponsoringFutureReservesOperation.java +++ b/src/main/java/org/stellar/sdk/BeginSponsoringFutureReservesOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class BeginSponsoringFutureReservesOperation extends Operation { @@ -59,8 +58,9 @@ public Builder(String sponsoredId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public BeginSponsoringFutureReservesOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public BeginSponsoringFutureReservesOperation.Builder setSourceAccount( + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/BumpSequenceOperation.java b/src/main/java/org/stellar/sdk/BumpSequenceOperation.java index 8f84a1abd..893855af8 100644 --- a/src/main/java/org/stellar/sdk/BumpSequenceOperation.java +++ b/src/main/java/org/stellar/sdk/BumpSequenceOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.BumpSequenceOp; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; @@ -65,8 +64,8 @@ public Builder(long bumpTo) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public BumpSequenceOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public BumpSequenceOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/ChangeTrustAsset.java b/src/main/java/org/stellar/sdk/ChangeTrustAsset.java index 9a96dded0..220db5d08 100644 --- a/src/main/java/org/stellar/sdk/ChangeTrustAsset.java +++ b/src/main/java/org/stellar/sdk/ChangeTrustAsset.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; +import lombok.NonNull; /** * ChangeTrustAsset class. @@ -127,9 +127,8 @@ public static ChangeTrustAsset fromXdr(org.stellar.sdk.xdr.ChangeTrustAsset xdr) public static final class Wrapper extends ChangeTrustAsset { private Asset asset; - public Wrapper(Asset baseAsset) { + public Wrapper(@NonNull Asset baseAsset) { super(); - checkNotNull(baseAsset, "asset cannot be null"); asset = baseAsset; } diff --git a/src/main/java/org/stellar/sdk/ChangeTrustOperation.java b/src/main/java/org/stellar/sdk/ChangeTrustOperation.java index 09b066f16..348de24d0 100644 --- a/src/main/java/org/stellar/sdk/ChangeTrustOperation.java +++ b/src/main/java/org/stellar/sdk/ChangeTrustOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.ChangeTrustOp; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; @@ -19,9 +18,9 @@ public class ChangeTrustOperation extends Operation { private final ChangeTrustAsset asset; private final String limit; - private ChangeTrustOperation(ChangeTrustAsset asset, String limit) { - this.asset = checkNotNull(asset, "asset cannot be null"); - this.limit = checkNotNull(limit, "limit cannot be null"); + private ChangeTrustOperation(@NonNull ChangeTrustAsset asset, @NonNull String limit) { + this.asset = asset; + this.limit = limit; } /** @@ -80,9 +79,9 @@ public static class Builder { * to 200 USD to a user, the limit is 200. * @throws ArithmeticException when limit has more than 7 decimal places. */ - public Builder(ChangeTrustAsset asset, String limit) { - this.asset = checkNotNull(asset, "asset cannot be null"); - this.limit = checkNotNull(limit, "limit cannot be null"); + public Builder(@NonNull ChangeTrustAsset asset, @NonNull String limit) { + this.asset = asset; + this.limit = limit; } /** @@ -91,8 +90,8 @@ public Builder(ChangeTrustAsset asset, String limit) { * @param sourceAccount Source account * @return Builder object so you can chain methods. */ - public Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java index fda2895c1..55f0c3412 100644 --- a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java @@ -1,17 +1,16 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.common.io.BaseEncoding; import java.io.IOException; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class ClaimClaimableBalanceOperation extends Operation { private final String balanceId; - private ClaimClaimableBalanceOperation(String balanceId) { - this.balanceId = checkNotNull(balanceId, "balanceId cannot be null"); + private ClaimClaimableBalanceOperation(@NonNull String balanceId) { + this.balanceId = balanceId; } public String getBalanceId() { @@ -70,8 +69,8 @@ public Builder(String balanceId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public ClaimClaimableBalanceOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public ClaimClaimableBalanceOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java index cf09c6f9d..11e149cff 100644 --- a/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java @@ -1,10 +1,9 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.common.io.BaseEncoding; import java.io.IOException; +import lombok.NonNull; import org.stellar.sdk.xdr.ClaimableBalanceID; import org.stellar.sdk.xdr.ClawbackClaimableBalanceOp; import org.stellar.sdk.xdr.OperationType; @@ -18,8 +17,8 @@ public class ClawbackClaimableBalanceOperation extends Operation { private final String balanceId; - private ClawbackClaimableBalanceOperation(String balanceId) { - this.balanceId = checkNotNull(balanceId, "balanceId cannot be null"); + private ClawbackClaimableBalanceOperation(@NonNull String balanceId) { + this.balanceId = balanceId; } /** The id of the claimable balance which will be clawed back. */ diff --git a/src/main/java/org/stellar/sdk/ClawbackOperation.java b/src/main/java/org/stellar/sdk/ClawbackOperation.java index 40ad905ee..e4957dedf 100644 --- a/src/main/java/org/stellar/sdk/ClawbackOperation.java +++ b/src/main/java/org/stellar/sdk/ClawbackOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -16,10 +15,11 @@ public class ClawbackOperation extends Operation { private final AssetTypeCreditAlphaNum mAsset; private final String mAmount; - private ClawbackOperation(String from, AssetTypeCreditAlphaNum asset, String amount) { - mFrom = checkNotNull(from, "from cannot be null"); - mAsset = checkNotNull(asset, "asset cannot be null"); - mAmount = checkNotNull(amount, "amount cannot be null"); + private ClawbackOperation( + @NonNull String from, @NonNull AssetTypeCreditAlphaNum asset, @NonNull String amount) { + mFrom = from; + mAsset = asset; + mAmount = amount; } /** The account owning of the trustline. */ diff --git a/src/main/java/org/stellar/sdk/CreateAccountOperation.java b/src/main/java/org/stellar/sdk/CreateAccountOperation.java index e4861fe28..b83bc4c37 100644 --- a/src/main/java/org/stellar/sdk/CreateAccountOperation.java +++ b/src/main/java/org/stellar/sdk/CreateAccountOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.CreateAccountOp; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; @@ -19,9 +18,9 @@ public class CreateAccountOperation extends Operation { private final String destination; private final String startingBalance; - private CreateAccountOperation(String destination, String startingBalance) { - this.destination = checkNotNull(destination, "destination cannot be null"); - this.startingBalance = checkNotNull(startingBalance, "startingBalance cannot be null"); + private CreateAccountOperation(@NonNull String destination, @NonNull String startingBalance) { + this.destination = destination; + this.startingBalance = startingBalance; } /** Amount of XLM to send to the newly created account. */ diff --git a/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java index eb73e7e3e..5d421995f 100644 --- a/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java @@ -1,10 +1,9 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.common.collect.Lists; import java.util.List; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class CreateClaimableBalanceOperation extends Operation { @@ -12,10 +11,11 @@ public class CreateClaimableBalanceOperation extends Operation { private final Asset asset; private final List claimants; - private CreateClaimableBalanceOperation(String amount, Asset asset, List claimants) { - this.asset = checkNotNull(asset, "asset cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.claimants = checkNotNull(claimants, "claimants cannot be null"); + private CreateClaimableBalanceOperation( + @NonNull String amount, @NonNull Asset asset, @NonNull List claimants) { + this.asset = asset; + this.amount = amount; + this.claimants = claimants; if (this.claimants.isEmpty()) { throw new IllegalArgumentException("claimants cannot be empty"); } @@ -108,8 +108,8 @@ public Builder(String amount, Asset asset, List claimants) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public CreateClaimableBalanceOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public CreateClaimableBalanceOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/CreatePassiveSellOfferOperation.java b/src/main/java/org/stellar/sdk/CreatePassiveSellOfferOperation.java index e9ae8031d..f9448a59e 100644 --- a/src/main/java/org/stellar/sdk/CreatePassiveSellOfferOperation.java +++ b/src/main/java/org/stellar/sdk/CreatePassiveSellOfferOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.CreatePassiveSellOfferOp; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; @@ -22,11 +21,14 @@ public class CreatePassiveSellOfferOperation extends Operation { private final String price; private CreatePassiveSellOfferOperation( - Asset selling, Asset buying, String amount, String price) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; } /** The asset being sold in this operation */ @@ -103,11 +105,15 @@ public static class Builder { * @param price Price of 1 unit of selling in terms of buying. * @throws ArithmeticException when amount has more than 7 decimal places. */ - public Builder(Asset selling, Asset buying, String amount, String price) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + public Builder( + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; } /** @@ -116,8 +122,8 @@ public Builder(Asset selling, Asset buying, String amount, String price) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public CreatePassiveSellOfferOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public CreatePassiveSellOfferOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/EndSponsoringFutureReservesOperation.java b/src/main/java/org/stellar/sdk/EndSponsoringFutureReservesOperation.java index 3c6a2c7f4..9d35a8a53 100644 --- a/src/main/java/org/stellar/sdk/EndSponsoringFutureReservesOperation.java +++ b/src/main/java/org/stellar/sdk/EndSponsoringFutureReservesOperation.java @@ -1,15 +1,14 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.OperationType; public class EndSponsoringFutureReservesOperation extends Operation { public EndSponsoringFutureReservesOperation() {} - public EndSponsoringFutureReservesOperation(String sourceAccount) { - setSourceAccount(checkNotNull(sourceAccount, "sourceAccount cannot be null")); + public EndSponsoringFutureReservesOperation(@NonNull String sourceAccount) { + setSourceAccount(sourceAccount); } @Override diff --git a/src/main/java/org/stellar/sdk/FeeBumpTransaction.java b/src/main/java/org/stellar/sdk/FeeBumpTransaction.java index 410a6df34..67ddc7446 100644 --- a/src/main/java/org/stellar/sdk/FeeBumpTransaction.java +++ b/src/main/java/org/stellar/sdk/FeeBumpTransaction.java @@ -1,10 +1,9 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.common.collect.Lists; import java.util.Arrays; +import lombok.NonNull; import org.stellar.sdk.xdr.DecoratedSignature; import org.stellar.sdk.xdr.EnvelopeType; import org.stellar.sdk.xdr.FeeBumpTransactionEnvelope; @@ -23,12 +22,12 @@ public class FeeBumpTransaction extends AbstractTransaction { FeeBumpTransaction( AccountConverter accountConverter, - String feeAccount, + @NonNull String feeAccount, long fee, - Transaction innerTransaction) { + @NonNull Transaction innerTransaction) { super(accountConverter, innerTransaction.getNetwork()); - this.mFeeAccount = checkNotNull(feeAccount, "feeAccount cannot be null"); - this.mInner = checkNotNull(innerTransaction, "innerTransaction cannot be null"); + this.mFeeAccount = feeAccount; + this.mInner = innerTransaction; this.mFee = fee; } @@ -122,10 +121,9 @@ public static class Builder { * @param accountConverter The AccountConverter which will be used to encode the fee account. * @param inner The inner transaction which will be fee bumped. read-only, the */ - public Builder(AccountConverter accountConverter, final Transaction inner) { - checkNotNull(inner, "inner cannot be null"); + public Builder(@NonNull AccountConverter accountConverter, @NonNull final Transaction inner) { EnvelopeType txType = inner.toEnvelopeXdr().getDiscriminant(); - this.mAccountConverter = checkNotNull(accountConverter, "accountConverter cannot be null"); + this.mAccountConverter = accountConverter; if (inner.toEnvelopeXdr().getDiscriminant() == EnvelopeType.ENVELOPE_TYPE_TX_V0) { this.mInner = new TransactionBuilder( @@ -186,22 +184,24 @@ public FeeBumpTransaction.Builder setBaseFee(long baseFee) { return this; } - public FeeBumpTransaction.Builder setFeeAccount(String feeAccount) { + public FeeBumpTransaction.Builder setFeeAccount(@NonNull String feeAccount) { if (this.mFeeAccount != null) { throw new RuntimeException("fee account has been already been set."); } - this.mFeeAccount = checkNotNull(feeAccount, "feeAccount cannot be null"); + this.mFeeAccount = feeAccount; return this; } public FeeBumpTransaction build() { + if (this.mFeeAccount == null) { + throw new NullPointerException("fee account has to be set. you must call setFeeAccount()."); + } + if (this.mBaseFee == null) { + throw new NullPointerException("base fee has to be set. you must call setBaseFee()."); + } return new FeeBumpTransaction( - this.mAccountConverter, - checkNotNull( - this.mFeeAccount, "fee account has to be set. you must call setFeeAccount()."), - checkNotNull(this.mBaseFee, "base fee has to be set. you must call setBaseFee()."), - this.mInner); + this.mAccountConverter, this.mFeeAccount, this.mBaseFee, this.mInner); } } diff --git a/src/main/java/org/stellar/sdk/KeyPair.java b/src/main/java/org/stellar/sdk/KeyPair.java index 55533db5a..eda4a0a8d 100644 --- a/src/main/java/org/stellar/sdk/KeyPair.java +++ b/src/main/java/org/stellar/sdk/KeyPair.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; import static java.lang.System.arraycopy; import com.google.common.base.Objects; @@ -11,6 +10,7 @@ import java.security.Signature; import java.security.SignatureException; import java.util.Arrays; +import lombok.NonNull; import net.i2p.crypto.eddsa.EdDSAEngine; import net.i2p.crypto.eddsa.EdDSAPrivateKey; import net.i2p.crypto.eddsa.EdDSAPublicKey; @@ -53,8 +53,8 @@ public KeyPair(EdDSAPublicKey publicKey) { * @param publicKey * @param privateKey */ - public KeyPair(EdDSAPublicKey publicKey, EdDSAPrivateKey privateKey) { - mPublicKey = checkNotNull(publicKey, "publicKey cannot be null"); + public KeyPair(@NonNull EdDSAPublicKey publicKey, EdDSAPrivateKey privateKey) { + mPublicKey = publicKey; mPrivateKey = privateKey; } diff --git a/src/main/java/org/stellar/sdk/LiquidityPoolConstantProductParameters.java b/src/main/java/org/stellar/sdk/LiquidityPoolConstantProductParameters.java index a79977c2a..b9a88248b 100644 --- a/src/main/java/org/stellar/sdk/LiquidityPoolConstantProductParameters.java +++ b/src/main/java/org/stellar/sdk/LiquidityPoolConstantProductParameters.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.LiquidityPoolType; /** @@ -24,10 +23,7 @@ public final class LiquidityPoolConstantProductParameters extends LiquidityPoolP * @param b Second asset in the liquidity pool * @param feeBP Fee amount in base-points */ - public LiquidityPoolConstantProductParameters(Asset a, Asset b, int feeBP) { - checkNotNull(a, "asset A cannot be null"); - checkNotNull(b, "asset B cannot be null"); - checkNotNull(feeBP, "fee cannot be null"); + public LiquidityPoolConstantProductParameters(@NonNull Asset a, @NonNull Asset b, int feeBP) { assetA = a; assetB = b; fee = feeBP; diff --git a/src/main/java/org/stellar/sdk/LiquidityPoolDepositOperation.java b/src/main/java/org/stellar/sdk/LiquidityPoolDepositOperation.java index b9d45b954..b8974d2f1 100644 --- a/src/main/java/org/stellar/sdk/LiquidityPoolDepositOperation.java +++ b/src/main/java/org/stellar/sdk/LiquidityPoolDepositOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.LiquidityPoolDepositOp; import org.stellar.sdk.xdr.LiquidityPoolType; import org.stellar.sdk.xdr.Operation.OperationBody; @@ -24,16 +23,16 @@ public class LiquidityPoolDepositOperation extends Operation { private final Price maxPrice; public LiquidityPoolDepositOperation( - LiquidityPoolID liquidityPoolID, - String maxAmountA, - String maxAmountB, - Price minPrice, - Price maxPrice) { - this.liquidityPoolID = checkNotNull(liquidityPoolID, "liquidityPoolID cannot be null"); - this.maxAmountA = checkNotNull(maxAmountA, "amountA cannot be null"); - this.maxAmountB = checkNotNull(maxAmountB, "amountB cannot be null"); - this.minPrice = checkNotNull(minPrice, "minPrice cannot be null"); - this.maxPrice = checkNotNull(maxPrice, "maxPrice cannot be null"); + @NonNull LiquidityPoolID liquidityPoolID, + @NonNull String maxAmountA, + @NonNull String maxAmountB, + @NonNull Price minPrice, + @NonNull Price maxPrice) { + this.liquidityPoolID = liquidityPoolID; + this.maxAmountA = maxAmountA; + this.maxAmountB = maxAmountB; + this.minPrice = minPrice; + this.maxPrice = maxPrice; } public LiquidityPoolDepositOperation(LiquidityPoolDepositOp op) { @@ -45,7 +44,7 @@ public LiquidityPoolDepositOperation(LiquidityPoolDepositOp op) { } public LiquidityPoolDepositOperation( - AssetAmount a, AssetAmount b, Price minPrice, Price maxPrice) { + AssetAmount a, AssetAmount b, @NonNull Price minPrice, @NonNull Price maxPrice) { if (a.getAsset().compareTo(b.getAsset()) >= 0) { throw new RuntimeException("AssetA must be < AssetB"); } @@ -57,8 +56,8 @@ public LiquidityPoolDepositOperation( LiquidityPoolParameters.Fee); this.maxAmountA = a.getAmount(); this.maxAmountB = b.getAmount(); - this.minPrice = checkNotNull(minPrice, "minPrice cannot be null"); - this.maxPrice = checkNotNull(maxPrice, "maxPrice cannot be null"); + this.minPrice = minPrice; + this.maxPrice = maxPrice; } public LiquidityPoolID getLiquidityPoolID() { diff --git a/src/main/java/org/stellar/sdk/LiquidityPoolShareChangeTrustAsset.java b/src/main/java/org/stellar/sdk/LiquidityPoolShareChangeTrustAsset.java index 0bd7c9247..37c894de9 100644 --- a/src/main/java/org/stellar/sdk/LiquidityPoolShareChangeTrustAsset.java +++ b/src/main/java/org/stellar/sdk/LiquidityPoolShareChangeTrustAsset.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.AssetType; /** @@ -19,8 +18,7 @@ public final class LiquidityPoolShareChangeTrustAsset extends ChangeTrustAsset { * * @param params the liquidity pool parameters */ - public LiquidityPoolShareChangeTrustAsset(LiquidityPoolParameters params) { - checkNotNull(params, "params cannot be null"); + public LiquidityPoolShareChangeTrustAsset(@NonNull LiquidityPoolParameters params) { mParams = params; } diff --git a/src/main/java/org/stellar/sdk/LiquidityPoolShareTrustLineAsset.java b/src/main/java/org/stellar/sdk/LiquidityPoolShareTrustLineAsset.java index 0dcee17f3..1abff6132 100644 --- a/src/main/java/org/stellar/sdk/LiquidityPoolShareTrustLineAsset.java +++ b/src/main/java/org/stellar/sdk/LiquidityPoolShareTrustLineAsset.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.AssetType; /** @@ -19,8 +18,7 @@ public final class LiquidityPoolShareTrustLineAsset extends TrustLineAsset { * * @param params the LiquidityPoolParameters */ - public LiquidityPoolShareTrustLineAsset(LiquidityPoolParameters params) { - checkNotNull(params, "params cannot be null"); + public LiquidityPoolShareTrustLineAsset(@NonNull LiquidityPoolParameters params) { mId = params.getId(); } @@ -29,8 +27,7 @@ public LiquidityPoolShareTrustLineAsset(LiquidityPoolParameters params) { * * @param id the LiquidityPoolID */ - public LiquidityPoolShareTrustLineAsset(LiquidityPoolID id) { - checkNotNull(id, "id cannot be null"); + public LiquidityPoolShareTrustLineAsset(@NonNull LiquidityPoolID id) { mId = id; } diff --git a/src/main/java/org/stellar/sdk/LiquidityPoolWithdrawOperation.java b/src/main/java/org/stellar/sdk/LiquidityPoolWithdrawOperation.java index c6c8a0931..321ae0b15 100644 --- a/src/main/java/org/stellar/sdk/LiquidityPoolWithdrawOperation.java +++ b/src/main/java/org/stellar/sdk/LiquidityPoolWithdrawOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.LiquidityPoolType; import org.stellar.sdk.xdr.LiquidityPoolWithdrawOp; import org.stellar.sdk.xdr.Operation.OperationBody; @@ -23,11 +22,14 @@ public class LiquidityPoolWithdrawOperation extends Operation { private final String minAmountB; public LiquidityPoolWithdrawOperation( - LiquidityPoolID liquidityPoolID, String amount, String minAmountA, String minAmountB) { - this.liquidityPoolID = checkNotNull(liquidityPoolID, "liquidityPoolID cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.minAmountA = checkNotNull(minAmountA, "minAmountA cannot be null"); - this.minAmountB = checkNotNull(minAmountB, "minAmountB cannot be null"); + @NonNull LiquidityPoolID liquidityPoolID, + @NonNull String amount, + @NonNull String minAmountA, + @NonNull String minAmountB) { + this.liquidityPoolID = liquidityPoolID; + this.amount = amount; + this.minAmountA = minAmountA; + this.minAmountB = minAmountB; } public LiquidityPoolWithdrawOperation(LiquidityPoolWithdrawOp op) { @@ -37,14 +39,14 @@ public LiquidityPoolWithdrawOperation(LiquidityPoolWithdrawOp op) { this.minAmountB = Operation.fromXdrAmount(op.getMinAmountB().getInt64().longValue()); } - public LiquidityPoolWithdrawOperation(AssetAmount a, AssetAmount b, String amount) { + public LiquidityPoolWithdrawOperation(AssetAmount a, AssetAmount b, @NonNull String amount) { this.liquidityPoolID = new LiquidityPoolID( LiquidityPoolType.LIQUIDITY_POOL_CONSTANT_PRODUCT, a.getAsset(), b.getAsset(), LiquidityPoolParameters.Fee); - this.amount = checkNotNull(amount, "amount cannot be null"); + this.amount = amount; this.minAmountA = a.getAmount(); this.minAmountB = b.getAmount(); } diff --git a/src/main/java/org/stellar/sdk/ManageBuyOfferOperation.java b/src/main/java/org/stellar/sdk/ManageBuyOfferOperation.java index 66c9f768d..b3bc9be16 100644 --- a/src/main/java/org/stellar/sdk/ManageBuyOfferOperation.java +++ b/src/main/java/org/stellar/sdk/ManageBuyOfferOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -22,11 +21,15 @@ public class ManageBuyOfferOperation extends Operation { private final long offerId; private ManageBuyOfferOperation( - Asset selling, Asset buying, String amount, String price, long offerId) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price, + long offerId) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; // offerId can be null this.offerId = offerId; } @@ -117,11 +120,15 @@ public static class Builder { * @param price Price of thing being bought in terms of what you are selling. * @throws ArithmeticException when amount has more than 7 decimal places. */ - public Builder(Asset selling, Asset buying, String amount, String price) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + public Builder( + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; } /** @@ -140,8 +147,8 @@ public Builder setOfferId(long offerId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/ManageDataOperation.java b/src/main/java/org/stellar/sdk/ManageDataOperation.java index 3d4a488f1..781c002fc 100644 --- a/src/main/java/org/stellar/sdk/ManageDataOperation.java +++ b/src/main/java/org/stellar/sdk/ManageDataOperation.java @@ -1,9 +1,8 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import java.util.Arrays; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -17,8 +16,8 @@ public class ManageDataOperation extends Operation { private final String name; private final byte[] value; - private ManageDataOperation(String name, byte[] value) { - this.name = checkNotNull(name, "name cannot be null"); + private ManageDataOperation(@NonNull String name, byte[] value) { + this.name = name; this.value = value; if (new XdrString(this.name).getBytes().length > 64) { @@ -84,8 +83,8 @@ public static class Builder { * @param name The name of data entry * @param value The value of data entry. nullnull will delete data entry. */ - public Builder(String name, byte[] value) { - this.name = checkNotNull(name, "name cannot be null"); + public Builder(@NonNull String name, byte[] value) { + this.name = name; this.value = value; } @@ -95,8 +94,8 @@ public Builder(String name, byte[] value) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/ManageSellOfferOperation.java b/src/main/java/org/stellar/sdk/ManageSellOfferOperation.java index 1594cd1aa..7bca522fa 100644 --- a/src/main/java/org/stellar/sdk/ManageSellOfferOperation.java +++ b/src/main/java/org/stellar/sdk/ManageSellOfferOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -22,11 +21,15 @@ public class ManageSellOfferOperation extends Operation { private final long offerId; private ManageSellOfferOperation( - Asset selling, Asset buying, String amount, String price, long offerId) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price, + long offerId) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; // offerId can be null this.offerId = offerId; } @@ -117,11 +120,15 @@ public static class Builder { * @param price Price of 1 unit of selling in terms of buying. * @throws ArithmeticException when amount has more than 7 decimal places. */ - public Builder(Asset selling, Asset buying, String amount, String price) { - this.selling = checkNotNull(selling, "selling cannot be null"); - this.buying = checkNotNull(buying, "buying cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); + public Builder( + @NonNull Asset selling, + @NonNull Asset buying, + @NonNull String amount, + @NonNull String price) { + this.selling = selling; + this.buying = buying; + this.amount = amount; + this.price = price; } /** @@ -140,8 +147,8 @@ public Builder setOfferId(long offerId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/MemoHashAbstract.java b/src/main/java/org/stellar/sdk/MemoHashAbstract.java index 1c664ae4d..423d1d7b2 100644 --- a/src/main/java/org/stellar/sdk/MemoHashAbstract.java +++ b/src/main/java/org/stellar/sdk/MemoHashAbstract.java @@ -1,16 +1,15 @@ package org.stellar.sdk; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.base.Preconditions.checkNotNull; import com.google.common.io.BaseEncoding; import java.util.Arrays; +import lombok.NonNull; abstract class MemoHashAbstract extends Memo { protected byte[] bytes; - public MemoHashAbstract(byte[] bytes) { - checkNotNull(bytes, "bytes cannot be null"); + public MemoHashAbstract(byte @NonNull [] bytes) { checkArgument(bytes.length == 32, "bytes must be 32-bytes long."); this.bytes = bytes; } diff --git a/src/main/java/org/stellar/sdk/MemoText.java b/src/main/java/org/stellar/sdk/MemoText.java index 8d85aa4d1..cad752e0b 100644 --- a/src/main/java/org/stellar/sdk/MemoText.java +++ b/src/main/java/org/stellar/sdk/MemoText.java @@ -1,8 +1,8 @@ package org.stellar.sdk; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.base.Preconditions.checkNotNull; +import lombok.NonNull; import org.stellar.sdk.xdr.MemoType; import org.stellar.sdk.xdr.XdrString; @@ -10,16 +10,15 @@ public class MemoText extends Memo { private XdrString text; - public MemoText(String text) { - this(new XdrString(checkNotNull(text, "text cannot be null"))); + public MemoText(@NonNull String text) { + this(new XdrString(text)); } - public MemoText(byte[] text) { - this(new XdrString(checkNotNull(text, "text cannot be null"))); + public MemoText(byte @NonNull [] text) { + this(new XdrString(text)); } - public MemoText(XdrString text) { - checkNotNull(text, "text cannot be null"); + public MemoText(@NonNull XdrString text) { checkArgument(text.getBytes().length <= 28, "text cannot be more than 28-bytes long."); this.text = text; } diff --git a/src/main/java/org/stellar/sdk/Network.java b/src/main/java/org/stellar/sdk/Network.java index d82eaad71..3711a0e91 100644 --- a/src/main/java/org/stellar/sdk/Network.java +++ b/src/main/java/org/stellar/sdk/Network.java @@ -1,9 +1,8 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import java.nio.charset.Charset; +import lombok.NonNull; /** * Network class is used to specify which Stellar network you want to use. Each network has a @@ -25,8 +24,8 @@ public class Network { * * @param networkPassphrase */ - public Network(String networkPassphrase) { - this.networkPassphrase = checkNotNull(networkPassphrase, "networkPassphrase cannot be null"); + public Network(@NonNull String networkPassphrase) { + this.networkPassphrase = networkPassphrase; } /** Returns network passphrase */ diff --git a/src/main/java/org/stellar/sdk/Operation.java b/src/main/java/org/stellar/sdk/Operation.java index f9af93cb3..840c7a25d 100644 --- a/src/main/java/org/stellar/sdk/Operation.java +++ b/src/main/java/org/stellar/sdk/Operation.java @@ -1,11 +1,10 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import java.io.IOException; import java.math.BigDecimal; import lombok.EqualsAndHashCode; import lombok.Getter; +import lombok.NonNull; import lombok.Setter; import lombok.experimental.SuperBuilder; @@ -19,8 +18,7 @@ public abstract class Operation { private static final BigDecimal ONE = new BigDecimal(10).pow(7); - protected static long toXdrAmount(String value) { - value = checkNotNull(value, "value cannot be null"); + protected static long toXdrAmount(@NonNull String value) { BigDecimal amount = new BigDecimal(value).multiply(Operation.ONE); return amount.longValueExact(); } diff --git a/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java b/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java index 7588b17e2..6b0227932 100644 --- a/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java +++ b/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java @@ -1,10 +1,10 @@ package org.stellar.sdk; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.base.Preconditions.checkNotNull; import com.google.common.base.Objects; import java.util.Arrays; +import lombok.NonNull; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; import org.stellar.sdk.xdr.PathPaymentStrictReceiveOp; @@ -27,17 +27,17 @@ public class PathPaymentStrictReceiveOperation extends Operation { private final Asset[] path; private PathPaymentStrictReceiveOperation( - Asset sendAsset, - String sendMax, - String destination, - Asset destAsset, - String destAmount, + @NonNull Asset sendAsset, + @NonNull String sendMax, + @NonNull String destination, + @NonNull Asset destAsset, + @NonNull String destAmount, Asset[] path) { - this.sendAsset = checkNotNull(sendAsset, "sendAsset cannot be null"); - this.sendMax = checkNotNull(sendMax, "sendMax cannot be null"); - this.destination = checkNotNull(destination, "destination cannot be null"); - this.destAsset = checkNotNull(destAsset, "destAsset cannot be null"); - this.destAmount = checkNotNull(destAmount, "destAmount cannot be null"); + this.sendAsset = sendAsset; + this.sendMax = sendMax; + this.destination = destination; + this.destAsset = destAsset; + this.destAmount = destAmount; if (path == null) { this.path = new Asset[0]; } else { @@ -150,12 +150,16 @@ public static class Builder { * @throws ArithmeticException when sendMax or destAmount has more than 7 decimal places. */ public Builder( - Asset sendAsset, String sendMax, String destination, Asset destAsset, String destAmount) { - this.sendAsset = checkNotNull(sendAsset, "sendAsset cannot be null"); - this.sendMax = checkNotNull(sendMax, "sendMax cannot be null"); - this.destination = checkNotNull(destination, "destination cannot be null"); - this.destAsset = checkNotNull(destAsset, "destAsset cannot be null"); - this.destAmount = checkNotNull(destAmount, "destAmount cannot be null"); + @NonNull Asset sendAsset, + @NonNull String sendMax, + @NonNull String destination, + @NonNull Asset destAsset, + @NonNull String destAmount) { + this.sendAsset = sendAsset; + this.sendMax = sendMax; + this.destination = destination; + this.destAsset = destAsset; + this.destAmount = destAmount; } /** @@ -167,8 +171,7 @@ public Builder( * would contain XLM and BTC. * @return Builder object so you can chain methods. */ - public PathPaymentStrictReceiveOperation.Builder setPath(Asset[] path) { - checkNotNull(path, "path cannot be null"); + public PathPaymentStrictReceiveOperation.Builder setPath(@NonNull Asset[] path) { checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); this.path = path; return this; @@ -180,8 +183,9 @@ public PathPaymentStrictReceiveOperation.Builder setPath(Asset[] path) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public PathPaymentStrictReceiveOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public PathPaymentStrictReceiveOperation.Builder setSourceAccount( + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java b/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java index 37363f958..92ad00f27 100644 --- a/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java +++ b/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java @@ -1,10 +1,10 @@ package org.stellar.sdk; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.base.Preconditions.checkNotNull; import com.google.common.base.Objects; import java.util.Arrays; +import lombok.NonNull; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; import org.stellar.sdk.xdr.PathPaymentStrictSendOp; @@ -27,17 +27,17 @@ public class PathPaymentStrictSendOperation extends Operation { private final Asset[] path; private PathPaymentStrictSendOperation( - Asset sendAsset, - String sendAmount, - String destination, - Asset destAsset, - String destMin, + @NonNull Asset sendAsset, + @NonNull String sendAmount, + @NonNull String destination, + @NonNull Asset destAsset, + @NonNull String destMin, Asset[] path) { - this.sendAsset = checkNotNull(sendAsset, "sendAsset cannot be null"); - this.sendAmount = checkNotNull(sendAmount, "sendAmount cannot be null"); - this.destination = checkNotNull(destination, "destination cannot be null"); - this.destAsset = checkNotNull(destAsset, "destAsset cannot be null"); - this.destMin = checkNotNull(destMin, "destMin cannot be null"); + this.sendAsset = sendAsset; + this.sendAmount = sendAmount; + this.destination = destination; + this.destAsset = destAsset; + this.destMin = destMin; if (path == null) { this.path = new Asset[0]; } else { @@ -150,12 +150,16 @@ public static class Builder { * @throws ArithmeticException when sendAmount or destMin has more than 7 decimal places. */ public Builder( - Asset sendAsset, String sendAmount, String destination, Asset destAsset, String destMin) { - this.sendAsset = checkNotNull(sendAsset, "sendAsset cannot be null"); - this.sendAmount = checkNotNull(sendAmount, "sendAmount cannot be null"); - this.destination = checkNotNull(destination, "destination cannot be null"); - this.destAsset = checkNotNull(destAsset, "destAsset cannot be null"); - this.destMin = checkNotNull(destMin, "destMin cannot be null"); + @NonNull Asset sendAsset, + @NonNull String sendAmount, + @NonNull String destination, + @NonNull Asset destAsset, + @NonNull String destMin) { + this.sendAsset = sendAsset; + this.sendAmount = sendAmount; + this.destination = destination; + this.destAsset = destAsset; + this.destMin = destMin; } /** @@ -167,8 +171,7 @@ public Builder( * would contain XLM and BTC. * @return Builder object so you can chain methods. */ - public PathPaymentStrictSendOperation.Builder setPath(Asset[] path) { - checkNotNull(path, "path cannot be null"); + public PathPaymentStrictSendOperation.Builder setPath(@NonNull Asset[] path) { checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); this.path = path; return this; @@ -180,8 +183,8 @@ public PathPaymentStrictSendOperation.Builder setPath(Asset[] path) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public PathPaymentStrictSendOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public PathPaymentStrictSendOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/PaymentOperation.java b/src/main/java/org/stellar/sdk/PaymentOperation.java index c0d284781..56405fbe0 100644 --- a/src/main/java/org/stellar/sdk/PaymentOperation.java +++ b/src/main/java/org/stellar/sdk/PaymentOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.OperationType; import org.stellar.sdk.xdr.PaymentOp; @@ -20,10 +19,11 @@ public class PaymentOperation extends Operation { private final Asset asset; private final String amount; - private PaymentOperation(String destination, Asset asset, String amount) { - this.destination = checkNotNull(destination, "destination cannot be null"); - this.asset = checkNotNull(asset, "asset cannot be null"); - this.amount = checkNotNull(amount, "amount cannot be null"); + private PaymentOperation( + @NonNull String destination, @NonNull Asset asset, @NonNull String amount) { + this.destination = destination; + this.asset = asset; + this.amount = amount; } /** Account that receives the payment. */ diff --git a/src/main/java/org/stellar/sdk/Price.java b/src/main/java/org/stellar/sdk/Price.java index 6e1709530..109bbbbc8 100644 --- a/src/main/java/org/stellar/sdk/Price.java +++ b/src/main/java/org/stellar/sdk/Price.java @@ -1,13 +1,12 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.gson.annotations.SerializedName; import java.math.BigDecimal; import java.math.MathContext; import java.util.ArrayList; import java.util.List; +import lombok.NonNull; import org.stellar.sdk.xdr.Int32; /** Represents Price. Price in Stellar is represented as a fraction. */ @@ -46,8 +45,7 @@ public int getDenominator() { * * @param price Ex. "1.25" */ - public static Price fromString(String price) { - checkNotNull(price, "price cannot be null"); + public static Price fromString(@NonNull String price) { BigDecimal maxInt = new BigDecimal(Integer.MAX_VALUE); BigDecimal number = new BigDecimal(price); BigDecimal a; diff --git a/src/main/java/org/stellar/sdk/RevokeAccountSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeAccountSponsorshipOperation.java index fc0645a5c..12dbaa200 100644 --- a/src/main/java/org/stellar/sdk/RevokeAccountSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeAccountSponsorshipOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeAccountSponsorshipOperation extends Operation { @@ -64,8 +63,9 @@ public Builder(String accountId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public RevokeAccountSponsorshipOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public RevokeAccountSponsorshipOperation.Builder setSourceAccount( + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java index 763f47010..022307990 100644 --- a/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java @@ -1,10 +1,9 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.common.io.BaseEncoding; import java.io.IOException; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeClaimableBalanceSponsorshipOperation extends Operation { @@ -85,8 +84,8 @@ public Builder(String balanceId) { * @return Builder object so you can chain methods. */ public RevokeClaimableBalanceSponsorshipOperation.Builder setSourceAccount( - String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/RevokeDataSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeDataSponsorshipOperation.java index 001bfe79d..db1d9e651 100644 --- a/src/main/java/org/stellar/sdk/RevokeDataSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeDataSponsorshipOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeDataSponsorshipOperation extends Operation { @@ -78,8 +77,8 @@ public Builder(String accountId, String dataName) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public RevokeDataSponsorshipOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public RevokeDataSponsorshipOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/RevokeOfferSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeOfferSponsorshipOperation.java index 161b0a12d..b4ba04e3f 100644 --- a/src/main/java/org/stellar/sdk/RevokeOfferSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeOfferSponsorshipOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeOfferSponsorshipOperation extends Operation { @@ -78,8 +77,8 @@ public Builder(String seller, Long offerId) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public RevokeOfferSponsorshipOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public RevokeOfferSponsorshipOperation.Builder setSourceAccount(@NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/RevokeSignerSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeSignerSponsorshipOperation.java index d3918bced..84149e105 100644 --- a/src/main/java/org/stellar/sdk/RevokeSignerSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeSignerSponsorshipOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeSignerSponsorshipOperation extends Operation { @@ -74,8 +73,9 @@ public Builder(String accountId, SignerKey signer) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public RevokeSignerSponsorshipOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public RevokeSignerSponsorshipOperation.Builder setSourceAccount( + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/RevokeTrustlineSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeTrustlineSponsorshipOperation.java index bd91a5bd0..4371555ec 100644 --- a/src/main/java/org/stellar/sdk/RevokeTrustlineSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeTrustlineSponsorshipOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; public class RevokeTrustlineSponsorshipOperation extends Operation { @@ -76,8 +75,9 @@ public Builder(String accountId, TrustLineAsset asset) { * @param sourceAccount The operation's source account. * @return Builder object so you can chain methods. */ - public RevokeTrustlineSponsorshipOperation.Builder setSourceAccount(String sourceAccount) { - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + public RevokeTrustlineSponsorshipOperation.Builder setSourceAccount( + @NonNull String sourceAccount) { + mSourceAccount = sourceAccount; return this; } diff --git a/src/main/java/org/stellar/sdk/SetOptionsOperation.java b/src/main/java/org/stellar/sdk/SetOptionsOperation.java index 0a3e94927..8dc54e00f 100644 --- a/src/main/java/org/stellar/sdk/SetOptionsOperation.java +++ b/src/main/java/org/stellar/sdk/SetOptionsOperation.java @@ -1,8 +1,7 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; +import lombok.NonNull; import org.stellar.sdk.xdr.*; /** @@ -340,9 +339,7 @@ public Builder setHomeDomain(String homeDomain) { * @param weight The weight to attach to the signer (0-255). * @return Builder object so you can chain methods. */ - public Builder setSigner(SignerKey signer, Integer weight) { - checkNotNull(signer, "signer cannot be null"); - checkNotNull(weight, "weight cannot be null"); + public Builder setSigner(@NonNull SignerKey signer, @NonNull Integer weight) { this.signer = signer; signerWeight = weight & 0xFF; return this; diff --git a/src/main/java/org/stellar/sdk/SignedPayloadSigner.java b/src/main/java/org/stellar/sdk/SignedPayloadSigner.java index 0eb30b16b..15ae5ddcc 100644 --- a/src/main/java/org/stellar/sdk/SignedPayloadSigner.java +++ b/src/main/java/org/stellar/sdk/SignedPayloadSigner.java @@ -1,7 +1,6 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - +import lombok.NonNull; import org.stellar.sdk.xdr.AccountID; import org.stellar.sdk.xdr.PublicKey; import org.stellar.sdk.xdr.PublicKeyType; @@ -24,9 +23,7 @@ public class SignedPayloadSigner { * @param signerAccountId - the xdr AccountID * @param payload - the raw payload for a signed payload */ - public SignedPayloadSigner(AccountID signerAccountId, byte[] payload) { - checkNotNull(payload, "payload cannot be null"); - checkNotNull(signerAccountId, "accountId cannot be null"); + public SignedPayloadSigner(@NonNull AccountID signerAccountId, byte @NonNull [] payload) { if (payload.length > SIGNED_PAYLOAD_MAX_PAYLOAD_LENGTH) { throw new IllegalArgumentException( "invalid payload length, must be less than " + SIGNED_PAYLOAD_MAX_PAYLOAD_LENGTH); @@ -39,8 +36,8 @@ public SignedPayloadSigner(AccountID signerAccountId, byte[] payload) { throw new IllegalArgumentException( "invalid payload signer, only ED25519 public key accounts are supported currently"); } - this.signerAccountId = checkNotNull(signerAccountId); - this.payload = checkNotNull(payload); + this.signerAccountId = signerAccountId; + this.payload = payload; } /** diff --git a/src/main/java/org/stellar/sdk/Signer.java b/src/main/java/org/stellar/sdk/Signer.java index 9fa5e0af2..1f947bc8c 100644 --- a/src/main/java/org/stellar/sdk/Signer.java +++ b/src/main/java/org/stellar/sdk/Signer.java @@ -1,7 +1,6 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; - +import lombok.NonNull; import org.stellar.sdk.xdr.SignerKey; import org.stellar.sdk.xdr.SignerKeyType; import org.stellar.sdk.xdr.Uint256; @@ -15,8 +14,7 @@ public class Signer { * @param keyPair * @return org.stellar.sdk.xdr.SignerKey */ - public static SignerKey ed25519PublicKey(KeyPair keyPair) { - checkNotNull(keyPair, "keyPair cannot be null"); + public static SignerKey ed25519PublicKey(@NonNull KeyPair keyPair) { return keyPair.getXdrSignerKey(); } @@ -27,8 +25,7 @@ public static SignerKey ed25519PublicKey(KeyPair keyPair) { * @param hash * @return org.stellar.sdk.xdr.SignerKey */ - public static SignerKey sha256Hash(byte[] hash) { - checkNotNull(hash, "hash cannot be null"); + public static SignerKey sha256Hash(byte @NonNull [] hash) { SignerKey signerKey = new SignerKey(); Uint256 value = Signer.createUint256(hash); @@ -45,8 +42,7 @@ public static SignerKey sha256Hash(byte[] hash) { * @param tx * @return org.stellar.sdk.xdr.SignerKey */ - public static SignerKey preAuthTx(Transaction tx) { - checkNotNull(tx, "tx cannot be null"); + public static SignerKey preAuthTx(@NonNull Transaction tx) { SignerKey signerKey = new SignerKey(); Uint256 value = Signer.createUint256(tx.hash()); @@ -62,8 +58,7 @@ public static SignerKey preAuthTx(Transaction tx) { * @param hash * @return org.stellar.sdk.xdr.SignerKey */ - public static SignerKey preAuthTx(byte[] hash) { - checkNotNull(hash, "hash cannot be null"); + public static SignerKey preAuthTx(byte @NonNull [] hash) { SignerKey signerKey = new SignerKey(); Uint256 value = Signer.createUint256(hash); diff --git a/src/main/java/org/stellar/sdk/Transaction.java b/src/main/java/org/stellar/sdk/Transaction.java index 56beee7d7..3a48b3809 100644 --- a/src/main/java/org/stellar/sdk/Transaction.java +++ b/src/main/java/org/stellar/sdk/Transaction.java @@ -1,12 +1,12 @@ package org.stellar.sdk; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.base.Preconditions.checkNotNull; import com.google.common.base.Objects; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.Arrays; +import lombok.NonNull; import org.stellar.sdk.xdr.AccountID; import org.stellar.sdk.xdr.ClaimableBalanceID; import org.stellar.sdk.xdr.ClaimableBalanceIDType; @@ -42,18 +42,18 @@ public class Transaction extends AbstractTransaction { Transaction( AccountConverter accountConverter, - String sourceAccount, + @NonNull String sourceAccount, long fee, long sequenceNumber, - Operation[] operations, + @NonNull Operation[] operations, Memo memo, TransactionPreconditions preconditions, SorobanTransactionData sorobanData, Network network) { super(accountConverter, network); - this.mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); + this.mSourceAccount = sourceAccount; this.mSequenceNumber = sequenceNumber; - this.mOperations = checkNotNull(operations, "operations cannot be null"); + this.mOperations = operations; checkArgument(operations.length > 0, "At least one operation required"); this.mPreconditions = preconditions; this.mFee = fee; diff --git a/src/main/java/org/stellar/sdk/TransactionBuilder.java b/src/main/java/org/stellar/sdk/TransactionBuilder.java index 44dcb4794..91e1d165e 100644 --- a/src/main/java/org/stellar/sdk/TransactionBuilder.java +++ b/src/main/java/org/stellar/sdk/TransactionBuilder.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; import static com.google.common.collect.Lists.newArrayList; import static org.stellar.sdk.TransactionPreconditions.TIMEOUT_INFINITE; @@ -8,6 +7,7 @@ import java.math.BigInteger; import java.util.Collection; import java.util.List; +import lombok.NonNull; import org.stellar.sdk.TransactionPreconditions.TransactionPreconditionsBuilder; import org.stellar.sdk.xdr.SorobanTransactionData; import org.stellar.sdk.xdr.TimePoint; @@ -35,10 +35,12 @@ public class TransactionBuilder { * @param network the testnet or pubnet network to use */ public TransactionBuilder( - AccountConverter accountConverter, TransactionBuilderAccount sourceAccount, Network network) { - mAccountConverter = checkNotNull(accountConverter, "accountConverter cannot be null"); - mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null"); - mNetwork = checkNotNull(network, "Network cannot be null"); + @NonNull AccountConverter accountConverter, + @NonNull TransactionBuilderAccount sourceAccount, + @NonNull Network network) { + mAccountConverter = accountConverter; + mSourceAccount = sourceAccount; + mNetwork = network; mOperations = newArrayList(); mPreconditions = TransactionPreconditions.builder().build(); } @@ -67,8 +69,7 @@ public int getOperationsCount() { * @return Builder object so you can chain methods. * @see Operation */ - public TransactionBuilder addOperation(Operation operation) { - checkNotNull(operation, "operation cannot be null"); + public TransactionBuilder addOperation(@NonNull Operation operation) { mOperations.add(operation); return this; } @@ -81,8 +82,7 @@ public TransactionBuilder addOperation(Operation operation) { * @return Builder object so you can chain methods. * @see Operation */ - public TransactionBuilder addOperations(Collection operations) { - checkNotNull(operations, "operations cannot be null"); + public TransactionBuilder addOperations(@NonNull Collection operations) { mOperations.addAll(operations); return this; } @@ -94,8 +94,7 @@ public TransactionBuilder addOperations(Collection operations) { * @param preconditions the tx PreConditions * @return updated Builder object */ - public TransactionBuilder addPreconditions(TransactionPreconditions preconditions) { - checkNotNull(preconditions, "preconditions cannot be null"); + public TransactionBuilder addPreconditions(@NonNull TransactionPreconditions preconditions) { this.mPreconditions = preconditions; return this; } @@ -108,11 +107,10 @@ public TransactionBuilder addPreconditions(TransactionPreconditions precondition * @return Builder object so you can chain methods. * @see Memo */ - public TransactionBuilder addMemo(Memo memo) { + public TransactionBuilder addMemo(@NonNull Memo memo) { if (mMemo != null) { throw new RuntimeException("Memo has been already added."); } - checkNotNull(memo, "memo cannot be null"); mMemo = memo; return this; } @@ -127,8 +125,7 @@ public TransactionBuilder addMemo(Memo memo) { * @deprecated this method will be removed in upcoming releases, use addPreconditions() * instead for more control over preconditions. */ - public TransactionBuilder addTimeBounds(TimeBounds timeBounds) { - checkNotNull(timeBounds, "timeBounds cannot be null"); + public TransactionBuilder addTimeBounds(@NonNull TimeBounds timeBounds) { if (mPreconditions.getTimeBounds() != null) { throw new RuntimeException("TimeBounds already set."); } @@ -247,12 +244,7 @@ public Transaction build() { * based on sourceAccount's current sequence number + 1. */ public static Function IncrementedSequenceNumberFunc = - new Function() { - @Override - public Long apply(TransactionBuilderAccount sourceAccount) { - return sourceAccount.getIncrementedSequenceNumber(); - } - }; + sourceAccount -> sourceAccount.getIncrementedSequenceNumber(); @Deprecated public static org.stellar.sdk.xdr.TimeBounds buildTimeBounds(long minTime, long maxTime) { diff --git a/src/main/java/org/stellar/sdk/TrustLineAsset.java b/src/main/java/org/stellar/sdk/TrustLineAsset.java index 0bb5986f2..2d059a14e 100644 --- a/src/main/java/org/stellar/sdk/TrustLineAsset.java +++ b/src/main/java/org/stellar/sdk/TrustLineAsset.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkNotNull; +import lombok.NonNull; /** * TrustLineAsset class. @@ -144,9 +144,8 @@ public static TrustLineAsset fromXdr(org.stellar.sdk.xdr.TrustLineAsset xdr) { public static final class Wrapper extends TrustLineAsset { private Asset asset; - public Wrapper(Asset baseAsset) { + public Wrapper(@NonNull Asset baseAsset) { super(); - checkNotNull(baseAsset, "asset cannot be null"); asset = baseAsset; } diff --git a/src/main/java/org/stellar/sdk/requests/EffectsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/EffectsRequestBuilder.java index 3730ebec6..fa1c19c22 100644 --- a/src/main/java/org/stellar/sdk/requests/EffectsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/EffectsRequestBuilder.java @@ -1,9 +1,8 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.gson.reflect.TypeToken; import java.io.IOException; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -25,8 +24,7 @@ public EffectsRequestBuilder(OkHttpClient httpClient, HttpUrl serverURI) { * Account * @param account Account for which to get effects */ - public EffectsRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public EffectsRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "effects"); return this; } @@ -50,8 +48,7 @@ public EffectsRequestBuilder forLedger(long ledgerSeq) { * Transaction * @param transactionId Transaction ID for which to get effects */ - public EffectsRequestBuilder forTransaction(String transactionId) { - transactionId = checkNotNull(transactionId, "transactionId cannot be null"); + public EffectsRequestBuilder forTransaction(@NonNull String transactionId) { this.setSegments("transactions", transactionId, "effects"); return this; } diff --git a/src/main/java/org/stellar/sdk/requests/OffersRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/OffersRequestBuilder.java index d66671ad6..44475ce4d 100644 --- a/src/main/java/org/stellar/sdk/requests/OffersRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/OffersRequestBuilder.java @@ -1,9 +1,8 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.gson.reflect.TypeToken; import java.io.IOException; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -54,8 +53,7 @@ public OfferResponse offer(long offerId) throws IOException { * GET /accounts/{account}/offers */ @Deprecated - public OffersRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public OffersRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "offers"); return this; } diff --git a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java index 055deadd3..bca03692f 100644 --- a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java @@ -1,12 +1,11 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Joiner; import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; import java.util.Set; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -61,8 +60,7 @@ public OperationResponse operation(long operationId) throws IOException { * Account * @param account Account for which to get operations */ - public OperationsRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public OperationsRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "operations"); return this; } @@ -75,8 +73,7 @@ public OperationsRequestBuilder forAccount(String account) { * for ClaimableBalance * @param claimableBalance Claimable Balance for which to get operations */ - public OperationsRequestBuilder forClaimableBalance(String claimableBalance) { - claimableBalance = checkNotNull(claimableBalance, "claimableBalance cannot be null"); + public OperationsRequestBuilder forClaimableBalance(@NonNull String claimableBalance) { this.setSegments("claimable_balances", claimableBalance, "operations"); return this; } @@ -100,8 +97,7 @@ public OperationsRequestBuilder forLedger(long ledgerSeq) { * for Transaction * @param transactionId Transaction ID for which to get operations */ - public OperationsRequestBuilder forTransaction(String transactionId) { - transactionId = checkNotNull(transactionId, "transactionId cannot be null"); + public OperationsRequestBuilder forTransaction(@NonNull String transactionId) { this.setSegments("transactions", transactionId, "operations"); return this; } diff --git a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java index 6feb001a3..83dc532fe 100644 --- a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java @@ -1,12 +1,11 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Joiner; import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; import java.util.Set; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -30,8 +29,7 @@ public PaymentsRequestBuilder(OkHttpClient httpClient, HttpUrl serverURI) { * Account * @param account Account for which to get payments */ - public PaymentsRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public PaymentsRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "payments"); return this; } @@ -55,8 +53,7 @@ public PaymentsRequestBuilder forLedger(long ledgerSeq) { * Transaction * @param transactionId Transaction ID for which to get payments */ - public PaymentsRequestBuilder forTransaction(String transactionId) { - transactionId = checkNotNull(transactionId, "transactionId cannot be null"); + public PaymentsRequestBuilder forTransaction(@NonNull String transactionId) { this.setSegments("transactions", transactionId, "payments"); return this; } diff --git a/src/main/java/org/stellar/sdk/requests/TradesRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/TradesRequestBuilder.java index 6139951cd..9115bba61 100644 --- a/src/main/java/org/stellar/sdk/requests/TradesRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/TradesRequestBuilder.java @@ -1,9 +1,8 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.gson.reflect.TypeToken; import java.io.IOException; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -49,8 +48,7 @@ public TradesRequestBuilder counterAsset(Asset asset) { * Account * @param account Account for which to get trades */ - public TradesRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public TradesRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "trades"); return this; } @@ -85,8 +83,7 @@ public TradesRequestBuilder forLiquidityPool(String liquidityPoolID) { * @return current {@link TradesRequestBuilder} instance * @see List All Trades */ - public TradesRequestBuilder forTradeType(String tradeType) { - tradeType = checkNotNull(tradeType, "tradeType cannot be null"); + public TradesRequestBuilder forTradeType(@NonNull String tradeType) { uriBuilder.setQueryParameter(TRADE_TYPE_PARAMETER_NAME, tradeType); return this; } diff --git a/src/main/java/org/stellar/sdk/requests/TransactionsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/TransactionsRequestBuilder.java index fe2e8ebd9..fac6de464 100644 --- a/src/main/java/org/stellar/sdk/requests/TransactionsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/TransactionsRequestBuilder.java @@ -1,9 +1,8 @@ package org.stellar.sdk.requests; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.gson.reflect.TypeToken; import java.io.IOException; +import lombok.NonNull; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -55,8 +54,7 @@ public TransactionResponse transaction(String transactionId) throws IOException * for Account * @param account Account for which to get transactions */ - public TransactionsRequestBuilder forAccount(String account) { - account = checkNotNull(account, "account cannot be null"); + public TransactionsRequestBuilder forAccount(@NonNull String account) { this.setSegments("accounts", account, "transactions"); return this; } @@ -69,8 +67,7 @@ public TransactionsRequestBuilder forAccount(String account) { * for ClaimableBalance * @param claimableBalance Claimable Balance for which to get transactions */ - public TransactionsRequestBuilder forClaimableBalance(String claimableBalance) { - claimableBalance = checkNotNull(claimableBalance, "claimableBalance cannot be null"); + public TransactionsRequestBuilder forClaimableBalance(@NonNull String claimableBalance) { this.setSegments("claimable_balances", claimableBalance, "transactions"); return this; } diff --git a/src/main/java/org/stellar/sdk/responses/AccountResponse.java b/src/main/java/org/stellar/sdk/responses/AccountResponse.java index d537e732c..382c8ffb5 100644 --- a/src/main/java/org/stellar/sdk/responses/AccountResponse.java +++ b/src/main/java/org/stellar/sdk/responses/AccountResponse.java @@ -1,12 +1,12 @@ package org.stellar.sdk.responses; -import static com.google.common.base.Preconditions.checkNotNull; import static org.stellar.sdk.Asset.create; import com.google.common.base.Optional; import com.google.common.io.BaseEncoding; import com.google.gson.annotations.SerializedName; import java.util.HashMap; +import lombok.NonNull; import org.stellar.sdk.Asset; import org.stellar.sdk.KeyPair; import org.stellar.sdk.LiquidityPoolID; @@ -281,27 +281,26 @@ public static class Balance { private String sponsor; public Balance( - String assetType, + @NonNull String assetType, String assetCode, String assetIssuer, LiquidityPoolID liquidityPoolID, - String balance, + @NonNull String balance, String limit, - String buyingLiabilities, - String sellingLiabilities, + @NonNull String buyingLiabilities, + @NonNull String sellingLiabilities, Boolean isAuthorized, Boolean isAuthorizedToMaintainLiabilities, Integer lastModifiedLedger, String sponsor) { - this.assetType = checkNotNull(assetType, "assertType cannot be null"); - this.balance = checkNotNull(balance, "balance cannot be null"); + this.assetType = assetType; + this.balance = balance; this.limit = limit; this.assetCode = assetCode; this.assetIssuer = assetIssuer; this.liquidityPoolID = liquidityPoolID; - this.buyingLiabilities = checkNotNull(buyingLiabilities, "buyingLiabilities cannot be null"); - this.sellingLiabilities = - checkNotNull(sellingLiabilities, "sellingLiabilities cannot be null"); + this.buyingLiabilities = buyingLiabilities; + this.sellingLiabilities = sellingLiabilities; this.isAuthorized = isAuthorized; this.isAuthorizedToMaintainLiabilities = isAuthorizedToMaintainLiabilities; this.lastModifiedLedger = lastModifiedLedger; @@ -380,10 +379,10 @@ public static class Signer { @SerializedName("sponsor") private String sponsor; - public Signer(String key, String type, int weight, String sponsor) { - this.key = checkNotNull(key, "key cannot be null"); - this.type = checkNotNull(type, "type cannot be null"); - this.weight = checkNotNull(weight, "weight cannot be null"); + public Signer(@NonNull String key, @NonNull String type, int weight, String sponsor) { + this.key = key; + this.type = type; + this.weight = weight; // sponsor is an optional field this.sponsor = sponsor; } diff --git a/src/main/java/org/stellar/sdk/responses/LiquidityPoolResponse.java b/src/main/java/org/stellar/sdk/responses/LiquidityPoolResponse.java index 73ca48b48..9d48b1a7c 100644 --- a/src/main/java/org/stellar/sdk/responses/LiquidityPoolResponse.java +++ b/src/main/java/org/stellar/sdk/responses/LiquidityPoolResponse.java @@ -1,9 +1,8 @@ package org.stellar.sdk.responses; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Objects; import com.google.gson.annotations.SerializedName; +import lombok.NonNull; import org.stellar.sdk.Asset; import org.stellar.sdk.LiquidityPoolID; import org.stellar.sdk.xdr.LiquidityPoolType; @@ -81,14 +80,14 @@ public static class Reserve { @SerializedName("asset") private final Asset asset; - public Reserve(String amount, String asset) { - this.amount = checkNotNull(amount, "amount cannot be null"); - this.asset = Asset.create(checkNotNull(asset, "asset cannot be null")); + public Reserve(@NonNull String amount, @NonNull String asset) { + this.amount = amount; + this.asset = Asset.create(asset); } - public Reserve(String amount, Asset asset) { - this.amount = checkNotNull(amount, "amount cannot be null"); - this.asset = checkNotNull(asset, "asset cannot be null"); + public Reserve(@NonNull String amount, @NonNull Asset asset) { + this.amount = amount; + this.asset = asset; } public Asset getAsset() { diff --git a/src/main/java/org/stellar/sdk/responses/OrderBookResponse.java b/src/main/java/org/stellar/sdk/responses/OrderBookResponse.java index 0e89f2a08..5fef9ad0a 100644 --- a/src/main/java/org/stellar/sdk/responses/OrderBookResponse.java +++ b/src/main/java/org/stellar/sdk/responses/OrderBookResponse.java @@ -1,8 +1,7 @@ package org.stellar.sdk.responses; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.gson.annotations.SerializedName; +import lombok.NonNull; import org.stellar.sdk.Asset; import org.stellar.sdk.Price; @@ -61,10 +60,10 @@ public static class Row { @SerializedName("price_r") private final Price priceR; - Row(String amount, String price, Price priceR) { - this.amount = checkNotNull(amount, "amount cannot be null"); - this.price = checkNotNull(price, "price cannot be null"); - this.priceR = checkNotNull(priceR, "priceR cannot be null"); + Row(@NonNull String amount, @NonNull String price, @NonNull Price priceR) { + this.amount = amount; + this.price = price; + this.priceR = priceR; } public String getAmount() { diff --git a/src/main/java/org/stellar/sdk/responses/Page.java b/src/main/java/org/stellar/sdk/responses/Page.java index 916e5bf91..c2d766ae2 100644 --- a/src/main/java/org/stellar/sdk/responses/Page.java +++ b/src/main/java/org/stellar/sdk/responses/Page.java @@ -1,6 +1,5 @@ package org.stellar.sdk.responses; -import com.google.common.base.Preconditions; import com.google.gson.annotations.SerializedName; import com.google.gson.reflect.TypeToken; import java.io.IOException; @@ -45,13 +44,13 @@ public Page getNextPage(OkHttpClient httpClient) throws URISyntaxException, I if (this.getLinks().getNext() == null) { return null; } - TypeToken> type = - Preconditions.checkNotNull( - this.type, - "type cannot be null, is it being correctly set after the creation of this " - + getClass().getSimpleName() - + "?"); - ResponseHandler> responseHandler = new ResponseHandler>(type); + if (this.type == null) { + throw new NullPointerException( + "type cannot be null, is it being correctly set after the creation of this " + + getClass().getSimpleName() + + "?"); + } + ResponseHandler> responseHandler = new ResponseHandler>(this.type); String url = this.getLinks().getNext().getHref(); Request request = new Request.Builder().get().url(url).build(); diff --git a/src/main/java/org/stellar/sdk/responses/TransactionResponse.java b/src/main/java/org/stellar/sdk/responses/TransactionResponse.java index a3912c4fb..8064991c8 100644 --- a/src/main/java/org/stellar/sdk/responses/TransactionResponse.java +++ b/src/main/java/org/stellar/sdk/responses/TransactionResponse.java @@ -1,11 +1,10 @@ package org.stellar.sdk.responses; -import static com.google.common.base.Preconditions.checkNotNull; - import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; import java.util.List; +import lombok.NonNull; import lombok.Value; import org.stellar.sdk.Memo; @@ -183,8 +182,7 @@ public Memo getMemo() { return memo; } - public void setMemo(Memo memo) { - memo = checkNotNull(memo, "memo cannot be null"); + public void setMemo(@NonNull Memo memo) { if (this.memo != null) { throw new RuntimeException("Memo has been already set."); } diff --git a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java index 8e525e676..aa6228d9a 100644 --- a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java +++ b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java @@ -1007,7 +1007,7 @@ public void testNoNetworkSet() throws FormatException { .build(); fail(); } catch (NullPointerException e) { - assertTrue(e.getMessage().contains("Network cannot be null")); + assertTrue(e.getMessage().contains("network is marked non-null but is null")); } } From ec16beaeb7930de43903f10cbb0e0df6dc536bfb Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 11:34:42 +0800 Subject: [PATCH 02/20] Use `java.util.Optional` instead of `com.google.common.base.Optional`. --- .../java/org/stellar/sdk/Sep10Challenge.java | 4 ++-- src/main/java/org/stellar/sdk/Server.java | 4 ++-- src/main/java/org/stellar/sdk/StrKey.java | 4 ++-- .../stellar/sdk/requests/EventListener.java | 2 +- .../org/stellar/sdk/requests/SSEStream.java | 6 ++--- .../requests/TooManyRequestsException.java | 4 ++-- .../sdk/responses/AccountResponse.java | 18 +++++++------- .../responses/ClaimableBalanceResponse.java | 4 ++-- .../stellar/sdk/responses/OfferResponse.java | 4 ++-- .../responses/SubmitTransactionResponse.java | 24 +++++++++---------- .../stellar/sdk/responses/TradeResponse.java | 14 +++++------ .../sdk/responses/TransactionResponse.java | 12 +++++----- .../sdk/responses/effects/EffectResponse.java | 4 ++-- .../effects/TradeEffectResponse.java | 4 ++-- .../AccountMergeOperationResponse.java | 6 ++--- .../AllowTrustOperationResponse.java | 4 ++-- .../ChangeTrustOperationResponse.java | 4 ++-- ...laimClaimableBalanceOperationResponse.java | 4 ++-- .../operations/ClawbackOperationResponse.java | 4 ++-- .../CreateAccountOperationResponse.java | 4 ++-- ...soringFutureReservesOperationResponse.java | 4 ++-- .../operations/OperationResponse.java | 6 ++--- .../PathPaymentBaseOperationResponse.java | 6 ++--- .../RevokeSponsorshipOperationResponse.java | 20 ++++++++-------- .../org/stellar/sdk/StreamingSmokeTest.java | 2 +- .../sdk/requests/ResponseHandlerTest.java | 4 ++-- .../responses/AccountDeserializerTest.java | 22 ++++++++--------- .../AccountsPageDeserializerTest.java | 4 ++-- .../ClaimableBalancePageDeserializerTest.java | 2 +- .../responses/TradesPageDeserializerTest.java | 10 ++++---- .../TransactionDeserializerTest.java | 7 +++--- 31 files changed, 110 insertions(+), 111 deletions(-) diff --git a/src/main/java/org/stellar/sdk/Sep10Challenge.java b/src/main/java/org/stellar/sdk/Sep10Challenge.java index be86cd019..94a287644 100644 --- a/src/main/java/org/stellar/sdk/Sep10Challenge.java +++ b/src/main/java/org/stellar/sdk/Sep10Challenge.java @@ -1,7 +1,6 @@ package org.stellar.sdk; import com.google.common.base.Objects; -import com.google.common.base.Optional; import com.google.common.collect.HashMultimap; import com.google.common.collect.Multimap; import com.google.common.io.BaseEncoding; @@ -13,6 +12,7 @@ import java.util.HashMap; import java.util.HashSet; import java.util.Map; +import java.util.Optional; import java.util.Set; import org.stellar.sdk.xdr.DecoratedSignature; import org.stellar.sdk.xdr.Signature; @@ -512,7 +512,7 @@ public static Set verifyChallengeTransactionSigners( // are consumed only once on the transaction. Set allSigners = new HashSet(clientSigners); allSigners.add(serverKeyPair.getAccountId()); - Optional clientDomainSigner = Optional.absent(); + Optional clientDomainSigner = Optional.empty(); for (Operation op : transaction.getOperations()) { if (!(op instanceof ManageDataOperation)) { diff --git a/src/main/java/org/stellar/sdk/Server.java b/src/main/java/org/stellar/sdk/Server.java index 77c5473fe..c331d01ff 100644 --- a/src/main/java/org/stellar/sdk/Server.java +++ b/src/main/java/org/stellar/sdk/Server.java @@ -1,11 +1,11 @@ package org.stellar.sdk; -import com.google.common.base.Optional; import com.google.gson.reflect.TypeToken; import java.io.Closeable; import java.io.IOException; import java.net.SocketTimeoutException; import java.util.HashSet; +import java.util.Optional; import java.util.Set; import java.util.concurrent.TimeUnit; import java.util.concurrent.locks.Lock; @@ -62,7 +62,7 @@ public Server(String serverURI, OkHttpClient httpClient, OkHttpClient submitHttp this.serverURI = HttpUrl.parse(serverURI); this.httpClient = httpClient; this.submitHttpClient = submitHttpClient; - this.network = Optional.absent(); + this.network = Optional.empty(); this.networkLock = new ReentrantReadWriteLock(); } diff --git a/src/main/java/org/stellar/sdk/StrKey.java b/src/main/java/org/stellar/sdk/StrKey.java index 26db710b3..e86795b42 100644 --- a/src/main/java/org/stellar/sdk/StrKey.java +++ b/src/main/java/org/stellar/sdk/StrKey.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import com.google.common.base.Optional; import com.google.common.io.BaseEncoding; import com.google.common.primitives.Bytes; import java.io.ByteArrayInputStream; @@ -9,6 +8,7 @@ import java.io.IOException; import java.io.OutputStream; import java.util.Arrays; +import java.util.Optional; import org.stellar.sdk.xdr.AccountID; import org.stellar.sdk.xdr.CryptoKeyType; import org.stellar.sdk.xdr.MuxedAccount; @@ -382,7 +382,7 @@ public static Optional findByValue(byte value) { return Optional.of(versionByte); } } - return Optional.absent(); + return Optional.empty(); } public int getValue() { diff --git a/src/main/java/org/stellar/sdk/requests/EventListener.java b/src/main/java/org/stellar/sdk/requests/EventListener.java index f95366787..75b36d32c 100644 --- a/src/main/java/org/stellar/sdk/requests/EventListener.java +++ b/src/main/java/org/stellar/sdk/requests/EventListener.java @@ -1,6 +1,6 @@ package org.stellar.sdk.requests; -import com.google.common.base.Optional; +import java.util.Optional; /** This interface is used in {@link RequestBuilder} classes stream method. */ public interface EventListener { diff --git a/src/main/java/org/stellar/sdk/requests/SSEStream.java b/src/main/java/org/stellar/sdk/requests/SSEStream.java index 33a1f94f9..7a1fe5629 100644 --- a/src/main/java/org/stellar/sdk/requests/SSEStream.java +++ b/src/main/java/org/stellar/sdk/requests/SSEStream.java @@ -1,8 +1,8 @@ package org.stellar.sdk.requests; -import com.google.common.base.Optional; import java.io.Closeable; import java.net.SocketException; +import java.util.Optional; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; @@ -199,7 +199,7 @@ public void onOpen(EventSource eventSource, Response response) {} @Override public void onFailure( EventSource eventSource, @Nullable Throwable t, @Nullable Response response) { - Optional code = Optional.absent(); + Optional code = Optional.empty(); if (response != null) { code = Optional.of(response.code()); } @@ -212,7 +212,7 @@ public void onFailure( listener.onFailure(Optional.of(t), code); } } else { - Optional absent = Optional.absent(); + Optional absent = Optional.empty(); listener.onFailure(absent, code); } } diff --git a/src/main/java/org/stellar/sdk/requests/TooManyRequestsException.java b/src/main/java/org/stellar/sdk/requests/TooManyRequestsException.java index 850f9d377..bb56ead87 100644 --- a/src/main/java/org/stellar/sdk/requests/TooManyRequestsException.java +++ b/src/main/java/org/stellar/sdk/requests/TooManyRequestsException.java @@ -1,6 +1,6 @@ package org.stellar.sdk.requests; -import com.google.common.base.Optional; +import java.util.Optional; /** * Exception thrown when too many requests were sent to the Horizon server. @@ -21,6 +21,6 @@ public TooManyRequestsException(Integer retryAfter) { * is unknown. */ public Optional getRetryAfter() { - return Optional.fromNullable(retryAfter); + return Optional.ofNullable(retryAfter); } } diff --git a/src/main/java/org/stellar/sdk/responses/AccountResponse.java b/src/main/java/org/stellar/sdk/responses/AccountResponse.java index 382c8ffb5..795fddb1a 100644 --- a/src/main/java/org/stellar/sdk/responses/AccountResponse.java +++ b/src/main/java/org/stellar/sdk/responses/AccountResponse.java @@ -2,10 +2,10 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.common.io.BaseEncoding; import com.google.gson.annotations.SerializedName; import java.util.HashMap; +import java.util.Optional; import lombok.NonNull; import org.stellar.sdk.Asset; import org.stellar.sdk.KeyPair; @@ -163,7 +163,7 @@ public Integer getNumSponsored() { } public Optional getSponsor() { - return Optional.fromNullable(this.sponsor); + return Optional.ofNullable(this.sponsor); } /** Represents account thresholds. */ @@ -321,15 +321,15 @@ public String getAssetType() { } public Optional getAssetCode() { - return Optional.fromNullable(assetCode); + return Optional.ofNullable(assetCode); } public Optional getAssetIssuer() { - return Optional.fromNullable(assetIssuer); + return Optional.ofNullable(assetIssuer); } public Optional getLiquidityPoolID() { - return Optional.fromNullable(liquidityPoolID); + return Optional.ofNullable(liquidityPoolID); } public String getBalance() { @@ -337,11 +337,11 @@ public String getBalance() { } public Optional getBuyingLiabilities() { - return Optional.fromNullable(buyingLiabilities); + return Optional.ofNullable(buyingLiabilities); } public Optional getSellingLiabilities() { - return Optional.fromNullable(sellingLiabilities); + return Optional.ofNullable(sellingLiabilities); } public String getLimit() { @@ -361,7 +361,7 @@ public Integer getLastModifiedLedger() { } public Optional getSponsor() { - return Optional.fromNullable(this.sponsor); + return Optional.ofNullable(this.sponsor); } } @@ -408,7 +408,7 @@ public String getType() { } public Optional getSponsor() { - return Optional.fromNullable(this.sponsor); + return Optional.ofNullable(this.sponsor); } } diff --git a/src/main/java/org/stellar/sdk/responses/ClaimableBalanceResponse.java b/src/main/java/org/stellar/sdk/responses/ClaimableBalanceResponse.java index 15be5b25c..98b6f5ad1 100644 --- a/src/main/java/org/stellar/sdk/responses/ClaimableBalanceResponse.java +++ b/src/main/java/org/stellar/sdk/responses/ClaimableBalanceResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.util.List; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.Claimant; @@ -87,7 +87,7 @@ public String getLastModifiedTime() { } public Optional getSponsor() { - return Optional.fromNullable(this.sponsor); + return Optional.ofNullable(this.sponsor); } public String getPagingToken() { diff --git a/src/main/java/org/stellar/sdk/responses/OfferResponse.java b/src/main/java/org/stellar/sdk/responses/OfferResponse.java index 867db40ed..a2b9d5031 100644 --- a/src/main/java/org/stellar/sdk/responses/OfferResponse.java +++ b/src/main/java/org/stellar/sdk/responses/OfferResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; +import java.util.Optional; import org.stellar.sdk.Asset; /** @@ -109,7 +109,7 @@ public String getLastModifiedTime() { } public Optional getSponsor() { - return Optional.fromNullable(this.sponsor); + return Optional.ofNullable(this.sponsor); } public Links getLinks() { diff --git a/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java b/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java index aae843a81..b4ad29bbf 100644 --- a/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java +++ b/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java @@ -1,11 +1,11 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.common.io.BaseEncoding; import com.google.gson.annotations.SerializedName; import java.io.ByteArrayInputStream; import java.io.IOException; import java.util.ArrayList; +import java.util.Optional; import org.stellar.sdk.Server; import org.stellar.sdk.xdr.OperationResult; import org.stellar.sdk.xdr.OperationType; @@ -63,7 +63,7 @@ public Optional getEnvelopeXdr() { if (this.getExtras() != null) { return Optional.of(this.getExtras().getEnvelopeXdr()); } - return Optional.absent(); + return Optional.empty(); } } @@ -74,7 +74,7 @@ public Optional getResultXdr() { if (this.getExtras() != null) { return Optional.of(this.getExtras().getResultXdr()); } - return Optional.absent(); + return Optional.empty(); } } @@ -89,17 +89,17 @@ public Optional getResultXdr() { */ public Optional getOfferIdFromResult(int position) throws IOException { if (!this.isSuccess()) { - return Optional.absent(); + return Optional.empty(); } Optional optionalResult = getDecodedTransactionResult(); if (!optionalResult.isPresent()) { - return Optional.absent(); + return Optional.empty(); } TransactionResult result = optionalResult.get(); if (result.getResult().getResults()[position] == null) { - return Optional.absent(); + return Optional.empty(); } OperationResult operationResult = result.getResult().getResults()[position]; @@ -108,7 +108,7 @@ public Optional getOfferIdFromResult(int position) throws IOException { if (operationType == OperationType.MANAGE_SELL_OFFER) { if (operationResultTr.getManageSellOfferResult().getSuccess().getOffer().getOffer() == null) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( operationResultTr @@ -122,7 +122,7 @@ public Optional getOfferIdFromResult(int position) throws IOException { if (operationType == OperationType.MANAGE_BUY_OFFER) { if (operationResultTr.getManageBuyOfferResult().getSuccess().getOffer().getOffer() == null) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( operationResultTr @@ -134,22 +134,22 @@ public Optional getOfferIdFromResult(int position) throws IOException { .getInt64()); } - return Optional.absent(); + return Optional.empty(); } /** - * Decoding "TransactionResult" from "resultXdr". This will be Optional.absent() if + * Decoding "TransactionResult" from "resultXdr". This will be Optional.empty()() if * transaction has failed. */ public Optional getDecodedTransactionResult() throws IOException { if (!this.isSuccess()) { - return Optional.absent(); + return Optional.empty(); } if (this.transactionResult == null) { Optional resultXDR = this.getResultXdr(); if (!resultXDR.isPresent()) { - return Optional.absent(); + return Optional.empty(); } BaseEncoding base64Encoding = BaseEncoding.base64(); byte[] bytes = base64Encoding.decode(resultXDR.get()); diff --git a/src/main/java/org/stellar/sdk/responses/TradeResponse.java b/src/main/java/org/stellar/sdk/responses/TradeResponse.java index ec3daa363..671bd6b38 100644 --- a/src/main/java/org/stellar/sdk/responses/TradeResponse.java +++ b/src/main/java/org/stellar/sdk/responses/TradeResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.LiquidityPoolID; @@ -141,15 +141,15 @@ public boolean isBaseSeller() { } public Optional getBaseOfferId() { - return Optional.fromNullable(baseOfferId); + return Optional.ofNullable(baseOfferId); } public Optional getBaseAccount() { - return Optional.fromNullable(baseAccount); + return Optional.ofNullable(baseAccount); } public Optional getBaseLiquidityPoolID() { - return Optional.fromNullable(baseLiquidityPoolID); + return Optional.ofNullable(baseLiquidityPoolID); } public String getBaseAmount() { @@ -173,15 +173,15 @@ public String getBaseAssetIssuer() { } public Optional getCounterAccount() { - return Optional.fromNullable(counterAccount); + return Optional.ofNullable(counterAccount); } public Optional getCounterLiquidityPoolID() { - return Optional.fromNullable(counterLiquidityPoolID); + return Optional.ofNullable(counterLiquidityPoolID); } public Optional getCounterOfferId() { - return Optional.fromNullable(counterOfferId); + return Optional.ofNullable(counterOfferId); } public Asset getCounterAsset() { diff --git a/src/main/java/org/stellar/sdk/responses/TransactionResponse.java b/src/main/java/org/stellar/sdk/responses/TransactionResponse.java index 8064991c8..1864c5899 100644 --- a/src/main/java/org/stellar/sdk/responses/TransactionResponse.java +++ b/src/main/java/org/stellar/sdk/responses/TransactionResponse.java @@ -1,9 +1,9 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; import java.util.List; +import java.util.Optional; import lombok.NonNull; import lombok.Value; import org.stellar.sdk.Memo; @@ -92,7 +92,7 @@ public class TransactionResponse extends Response implements Pageable { public Optional getSourceAccountMuxed() { if (this.accountMuxed == null || this.accountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( new MuxedAccount(this.accountMuxed, this.sourceAccount, this.accountMuxedId)); @@ -100,7 +100,7 @@ public Optional getSourceAccountMuxed() { public Optional getFeeAccountMuxed() { if (this.feeAccountMuxed == null || this.feeAccountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( new MuxedAccount(this.feeAccountMuxed, this.feeAccount, this.feeAccountMuxedId)); @@ -131,15 +131,15 @@ public List getSignatures() { } public Optional getFeeBump() { - return Optional.fromNullable(this.feeBumpTransaction); + return Optional.ofNullable(this.feeBumpTransaction); } public Optional getInner() { - return Optional.fromNullable(this.innerTransaction); + return Optional.ofNullable(this.innerTransaction); } public Optional getPreconditions() { - return Optional.fromNullable(this.preconditions); + return Optional.ofNullable(this.preconditions); } public String getPagingToken() { diff --git a/src/main/java/org/stellar/sdk/responses/effects/EffectResponse.java b/src/main/java/org/stellar/sdk/responses/effects/EffectResponse.java index ee8f9a027..78935ca87 100644 --- a/src/main/java/org/stellar/sdk/responses/effects/EffectResponse.java +++ b/src/main/java/org/stellar/sdk/responses/effects/EffectResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.effects; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.Link; import org.stellar.sdk.responses.MuxedAccount; import org.stellar.sdk.responses.Pageable; @@ -51,7 +51,7 @@ public String getAccount() { public Optional getAccountMuxed() { if (this.accountMuxed == null || this.accountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.accountMuxed, this.account, this.accountMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/effects/TradeEffectResponse.java b/src/main/java/org/stellar/sdk/responses/effects/TradeEffectResponse.java index aca772d6d..fd63272d3 100644 --- a/src/main/java/org/stellar/sdk/responses/effects/TradeEffectResponse.java +++ b/src/main/java/org/stellar/sdk/responses/effects/TradeEffectResponse.java @@ -2,9 +2,9 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.responses.MuxedAccount; @@ -55,7 +55,7 @@ public class TradeEffectResponse extends EffectResponse { public Optional getSellerMuxed() { if (this.sellerMuxed == null || this.sellerMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.sellerMuxed, this.seller, this.sellerMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/AccountMergeOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/AccountMergeOperationResponse.java index f4a8e590e..591807069 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/AccountMergeOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/AccountMergeOperationResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.MuxedAccount; /** @@ -34,14 +34,14 @@ public class AccountMergeOperationResponse extends OperationResponse { public Optional getAccountMuxed() { if (this.accountMuxed == null || this.accountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.accountMuxed, this.account, this.accountMuxedId)); } public Optional getIntoMuxed() { if (this.intoMuxed == null || this.intoMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.intoMuxed, this.into, this.intoMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/AllowTrustOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/AllowTrustOperationResponse.java index d93fd9bd6..282937ccc 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/AllowTrustOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/AllowTrustOperationResponse.java @@ -2,9 +2,9 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.AssetTypeNative; import org.stellar.sdk.responses.MuxedAccount; @@ -51,7 +51,7 @@ public String getTrustor() { public Optional getTrusteeMuxed() { if (this.trusteeMuxed == null || this.trusteeMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.trusteeMuxed, this.trustee, this.trusteeMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/ChangeTrustOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/ChangeTrustOperationResponse.java index 27ea39c61..1d3dd26c5 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/ChangeTrustOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/ChangeTrustOperationResponse.java @@ -2,9 +2,9 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.responses.MuxedAccount; @@ -46,7 +46,7 @@ public class ChangeTrustOperationResponse extends OperationResponse { public Optional getTrustorMuxed() { if (this.trustorMuxed == null || this.trustorMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.trustorMuxed, this.trustor, this.trustorMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/ClaimClaimableBalanceOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/ClaimClaimableBalanceOperationResponse.java index 71948ba41..ee57a1d5e 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/ClaimClaimableBalanceOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/ClaimClaimableBalanceOperationResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.MuxedAccount; /** @@ -26,7 +26,7 @@ public class ClaimClaimableBalanceOperationResponse extends OperationResponse { public Optional getClaimantMuxed() { if (this.claimantMuxed == null || this.claimantMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.claimantMuxed, this.claimant, this.claimantMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/ClawbackOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/ClawbackOperationResponse.java index a013662ce..aa55318f3 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/ClawbackOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/ClawbackOperationResponse.java @@ -2,9 +2,9 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.responses.MuxedAccount; @@ -62,7 +62,7 @@ public String getFrom() { public Optional getFromMuxed() { if (this.fromMuxed == null || this.fromMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.fromMuxed, this.from, this.fromMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/CreateAccountOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/CreateAccountOperationResponse.java index 3360f5ba5..394de5282 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/CreateAccountOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/CreateAccountOperationResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.MuxedAccount; /** @@ -31,7 +31,7 @@ public class CreateAccountOperationResponse extends OperationResponse { public Optional getFunderMuxed() { if (this.funderAccountMuxed == null || this.funderAccountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( new MuxedAccount(this.funderAccountMuxed, this.funder, this.funderAccountMuxedId)); diff --git a/src/main/java/org/stellar/sdk/responses/operations/EndSponsoringFutureReservesOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/EndSponsoringFutureReservesOperationResponse.java index f4a85cce4..b03ff7ec9 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/EndSponsoringFutureReservesOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/EndSponsoringFutureReservesOperationResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.MuxedAccount; /** @@ -23,7 +23,7 @@ public class EndSponsoringFutureReservesOperationResponse extends OperationRespo public Optional getBeginSponsorMuxed() { if (this.beginSponsorMuxed == null || this.beginSponsorMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( new MuxedAccount(this.beginSponsorMuxed, this.beginSponsor, this.beginSponsorMuxedId)); diff --git a/src/main/java/org/stellar/sdk/responses/operations/OperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/OperationResponse.java index a3a35c31e..0ae97046c 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/OperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/OperationResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.Optional; import org.stellar.sdk.responses.*; /** @@ -49,7 +49,7 @@ public abstract class OperationResponse extends Response implements Pageable { public Optional getSourceAccountMuxed() { if (this.sourceAccountMuxed == null || this.sourceAccountMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of( new MuxedAccount(this.sourceAccountMuxed, this.sourceAccount, this.sourceAccountMuxedId)); @@ -106,7 +106,7 @@ public Links getLinks() { } public Optional getTransaction() { - return Optional.fromNullable(transaction); + return Optional.ofNullable(transaction); } /** Represents operation links. */ diff --git a/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java index 78d1b6f49..09e7b8d25 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java @@ -2,11 +2,11 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; import java.util.List; +import java.util.Optional; import org.stellar.sdk.Asset; import org.stellar.sdk.AssetTypeNative; import org.stellar.sdk.responses.MuxedAccount; @@ -71,14 +71,14 @@ public String getFrom() { public Optional getFromMuxed() { if (this.fromMuxed == null || this.fromMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.fromMuxed, this.from, this.fromMuxedId)); } public Optional getToMuxed() { if (this.toMuxed == null || this.toMuxed.isEmpty()) { - return Optional.absent(); + return Optional.empty(); } return Optional.of(new MuxedAccount(this.toMuxed, this.to, this.toMuxedId)); } diff --git a/src/main/java/org/stellar/sdk/responses/operations/RevokeSponsorshipOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/RevokeSponsorshipOperationResponse.java index f1f53c5e0..cada85534 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/RevokeSponsorshipOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/RevokeSponsorshipOperationResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses.operations; -import com.google.common.base.Optional; import com.google.gson.annotations.SerializedName; +import java.util.Optional; /** * Represents RevokeSponsorship operation response. @@ -59,38 +59,38 @@ public RevokeSponsorshipOperationResponse( } public Optional getAccountId() { - return Optional.fromNullable(accountId); + return Optional.ofNullable(accountId); } public Optional getClaimableBalanceId() { - return Optional.fromNullable(claimableBalanceId); + return Optional.ofNullable(claimableBalanceId); } public Optional getDataAccountId() { - return Optional.fromNullable(dataAccountId); + return Optional.ofNullable(dataAccountId); } public Optional getDataName() { - return Optional.fromNullable(dataName); + return Optional.ofNullable(dataName); } public Optional getOfferId() { - return Optional.fromNullable(offerId); + return Optional.ofNullable(offerId); } public Optional getTrustlineAccountId() { - return Optional.fromNullable(trustlineAccountId); + return Optional.ofNullable(trustlineAccountId); } public Optional getTrustlineAsset() { - return Optional.fromNullable(trustlineAsset); + return Optional.ofNullable(trustlineAsset); } public Optional getSignerAccountId() { - return Optional.fromNullable(signerAccountId); + return Optional.ofNullable(signerAccountId); } public Optional getSignerKey() { - return Optional.fromNullable(signerKey); + return Optional.ofNullable(signerKey); } } diff --git a/src/test/java/org/stellar/sdk/StreamingSmokeTest.java b/src/test/java/org/stellar/sdk/StreamingSmokeTest.java index 7f988aa17..068f2b7f6 100644 --- a/src/test/java/org/stellar/sdk/StreamingSmokeTest.java +++ b/src/test/java/org/stellar/sdk/StreamingSmokeTest.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Optional; +import java.util.Optional; import java.util.concurrent.atomic.AtomicInteger; import org.junit.Assert; import org.junit.Ignore; diff --git a/src/test/java/org/stellar/sdk/requests/ResponseHandlerTest.java b/src/test/java/org/stellar/sdk/requests/ResponseHandlerTest.java index 620a17216..8cbea5d26 100644 --- a/src/test/java/org/stellar/sdk/requests/ResponseHandlerTest.java +++ b/src/test/java/org/stellar/sdk/requests/ResponseHandlerTest.java @@ -2,8 +2,8 @@ import static org.junit.Assert.assertEquals; -import com.google.common.base.Optional; import java.io.IOException; +import java.util.Optional; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; import okhttp3.mockwebserver.MockWebServer; @@ -54,7 +54,7 @@ public void testTooManyRequestsNoHeader() throws IOException, InterruptedExcepti AccountsRequestBuilder.execute(okHttpClient, mockWebServer.url("/")); Assert.fail(); } catch (TooManyRequestsException tmre) { - assertEquals(Optional.absent(), tmre.getRetryAfter()); + assertEquals(Optional.empty(), tmre.getRetryAfter()); } finally { mockWebServer.shutdown(); diff --git a/src/test/java/org/stellar/sdk/responses/AccountDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/AccountDeserializerTest.java index f4f3fa96a..570c6e9ef 100644 --- a/src/test/java/org/stellar/sdk/responses/AccountDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/AccountDeserializerTest.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import java.util.Arrays; +import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.AssetTypeCreditAlphaNum4; @@ -155,14 +155,14 @@ public void testDeserializeV9() { "ABC", "GCRA6COW27CY5MTKIA7POQ2326C5ABYCXODBN4TFF5VL4FMBRHOT3YHU"))); assertEquals(account.getBalances()[0].getBalance(), "1001.0000000"); assertEquals(account.getBalances()[0].getLimit(), "12000.4775807"); - assertEquals(account.getBalances()[0].getBuyingLiabilities(), Optional.absent()); - assertEquals(account.getBalances()[0].getSellingLiabilities(), Optional.absent()); + assertEquals(account.getBalances()[0].getBuyingLiabilities(), Optional.empty()); + assertEquals(account.getBalances()[0].getSellingLiabilities(), Optional.empty()); assertEquals(account.getBalances()[1].getAssetType(), "native"); assertEquals(account.getBalances()[1].getAsset(), Optional.of(new AssetTypeNative())); assertEquals(account.getBalances()[1].getBalance(), "20.0000300"); - assertEquals(account.getBalances()[1].getBuyingLiabilities(), Optional.absent()); - assertEquals(account.getBalances()[1].getSellingLiabilities(), Optional.absent()); + assertEquals(account.getBalances()[1].getBuyingLiabilities(), Optional.empty()); + assertEquals(account.getBalances()[1].getSellingLiabilities(), Optional.empty()); assertEquals(account.getBalances()[1].getLimit(), null); } @@ -172,12 +172,12 @@ public void testDeserializeLiquidityPoolBalanc() { GsonSingleton.getInstance().fromJson(jsonLiquidityPoolBalance, AccountResponse.class); assertEquals(account.getBalances()[0].getAssetType(), "liquidity_pool_shares"); - assertEquals(account.getBalances()[0].getAssetCode(), Optional.absent()); - assertEquals(account.getBalances()[0].getAssetIssuer(), Optional.absent()); + assertEquals(account.getBalances()[0].getAssetCode(), Optional.empty()); + assertEquals(account.getBalances()[0].getAssetIssuer(), Optional.empty()); assertEquals(account.getBalances()[0].getBalance(), "223.6067977"); assertEquals(account.getBalances()[0].getLimit(), "10000.00000"); - assertEquals(account.getBalances()[0].getBuyingLiabilities(), Optional.absent()); - assertEquals(account.getBalances()[0].getSellingLiabilities(), Optional.absent()); + assertEquals(account.getBalances()[0].getBuyingLiabilities(), Optional.empty()); + assertEquals(account.getBalances()[0].getSellingLiabilities(), Optional.empty()); assertTrue(account.getBalances()[0].getLiquidityPoolID().isPresent()); assertEquals( account.getBalances()[0].getLiquidityPoolID().get().toString(), @@ -185,8 +185,8 @@ public void testDeserializeLiquidityPoolBalanc() { assertEquals(account.getBalances()[1].getAssetType(), "native"); assertEquals(account.getBalances()[1].getBalance(), "20.0000300"); - assertEquals(account.getBalances()[1].getBuyingLiabilities(), Optional.absent()); - assertEquals(account.getBalances()[1].getSellingLiabilities(), Optional.absent()); + assertEquals(account.getBalances()[1].getBuyingLiabilities(), Optional.empty()); + assertEquals(account.getBalances()[1].getSellingLiabilities(), Optional.empty()); assertEquals(account.getBalances()[1].getLimit(), null); } diff --git a/src/test/java/org/stellar/sdk/responses/AccountsPageDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/AccountsPageDeserializerTest.java index f4bc259ca..fb9d220f0 100644 --- a/src/test/java/org/stellar/sdk/responses/AccountsPageDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/AccountsPageDeserializerTest.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.reflect.TypeToken; +import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.LiquidityPoolID; @@ -43,7 +43,7 @@ public void testDeserializeWithLiquidityPoolBalance() { new LiquidityPoolID( "a468d41d8e9b8f3c7209651608b74b7db7ac9952dcae0cdf24871d1d9c7b0088"))); assertEquals( - accountsPage.getRecords().get(0).getBalances()[1].getLiquidityPoolID(), Optional.absent()); + accountsPage.getRecords().get(0).getBalances()[1].getLiquidityPoolID(), Optional.empty()); } String json = diff --git a/src/test/java/org/stellar/sdk/responses/ClaimableBalancePageDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/ClaimableBalancePageDeserializerTest.java index 56f189983..bdb50ee9f 100644 --- a/src/test/java/org/stellar/sdk/responses/ClaimableBalancePageDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/ClaimableBalancePageDeserializerTest.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses; -import com.google.common.base.Optional; import com.google.gson.reflect.TypeToken; +import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.Asset; diff --git a/src/test/java/org/stellar/sdk/responses/TradesPageDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/TradesPageDeserializerTest.java index 811f3deff..f6d697053 100644 --- a/src/test/java/org/stellar/sdk/responses/TradesPageDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/TradesPageDeserializerTest.java @@ -3,8 +3,8 @@ import static java.lang.Long.valueOf; import static org.stellar.sdk.Asset.create; -import com.google.common.base.Optional; import com.google.gson.reflect.TypeToken; +import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.AssetTypeNative; @@ -39,8 +39,8 @@ public void testDeserialize() { create(null, "JPY", "GBVAOIACNSB7OVUXJYC5UE2D4YK2F7A24T7EE5YOMN4CE6GCHUTOUQXM")); assertEquals(tradesPage.getRecords().get(0).getPrice().getNumerator(), valueOf(267)); assertEquals(tradesPage.getRecords().get(0).getPrice().getDenominator(), valueOf(1000)); - assertEquals(tradesPage.getRecords().get(0).getCounterLiquidityPoolID(), Optional.absent()); - assertEquals(tradesPage.getRecords().get(0).getBaseLiquidityPoolID(), Optional.absent()); + assertEquals(tradesPage.getRecords().get(0).getCounterLiquidityPoolID(), Optional.empty()); + assertEquals(tradesPage.getRecords().get(0).getBaseLiquidityPoolID(), Optional.empty()); assertEquals( tradesPage.getRecords().get(1).getBaseAccount(), @@ -58,8 +58,8 @@ public void testDeserializeLiquidityPool() { Optional.of( new LiquidityPoolID( "a468d41d8e9b8f3c7209651608b74b7db7ac9952dcae0cdf24871d1d9c7bbase"))); - assertEquals(tradesPage.getRecords().get(0).getCounterLiquidityPoolID(), Optional.absent()); - assertEquals(tradesPage.getRecords().get(1).getBaseLiquidityPoolID(), Optional.absent()); + assertEquals(tradesPage.getRecords().get(0).getCounterLiquidityPoolID(), Optional.empty()); + assertEquals(tradesPage.getRecords().get(1).getBaseLiquidityPoolID(), Optional.empty()); assertEquals( tradesPage.getRecords().get(1).getCounterLiquidityPoolID(), Optional.of( diff --git a/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java index 94d4fe781..dd1e86011 100644 --- a/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java @@ -3,9 +3,9 @@ import static java.math.BigInteger.valueOf; import static org.junit.Assert.assertEquals; -import com.google.common.base.Optional; import com.google.common.collect.ImmutableList; import java.util.Arrays; +import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.MemoHash; @@ -76,9 +76,8 @@ public void testDeserialize() { transaction.getSignatures(), ImmutableList.of( "b/noKPYnxb8oJmv6gLixY0PUJMZZ9pxwc226JtAfyRkhv6oFINj3iDuGJoBeuUh6D1vujP9e4/fH0xZjDaO3Aw==")); - assertEquals( - transaction.getFeeBump(), Optional.absent()); - assertEquals(transaction.getInner(), Optional.absent()); + assertEquals(transaction.getFeeBump(), Optional.empty()); + assertEquals(transaction.getInner(), Optional.empty()); assertTrue(transaction.getMemo() instanceof MemoHash); MemoHash memo = (MemoHash) transaction.getMemo(); assertEquals( From 7ac9b03e3e40cf2693eea676e2fc43b009c3fc9d Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 15:04:07 +0800 Subject: [PATCH 03/20] Use `java.util.Objects` instead of `com.google.common.base.Objects` --- src/main/java/org/stellar/sdk/Account.java | 8 +++--- .../stellar/sdk/AccountMergeOperation.java | 8 +++--- .../org/stellar/sdk/AllowTrustOperation.java | 14 +++++----- .../java/org/stellar/sdk/AssetAmount.java | 8 +++--- .../stellar/sdk/AssetTypeCreditAlphaNum.java | 4 +-- .../org/stellar/sdk/AssetTypePoolShare.java | 4 +-- ...eginSponsoringFutureReservesOperation.java | 8 +++--- .../stellar/sdk/BumpSequenceOperation.java | 8 +++--- .../org/stellar/sdk/ChangeTrustOperation.java | 10 +++---- .../sdk/ClaimClaimableBalanceOperation.java | 8 +++--- .../ClawbackClaimableBalanceOperation.java | 8 +++--- .../org/stellar/sdk/ClawbackOperation.java | 12 ++++----- .../stellar/sdk/CreateAccountOperation.java | 10 +++---- .../sdk/CreateClaimableBalanceOperation.java | 12 ++++----- .../sdk/CreatePassiveSellOfferOperation.java | 14 +++++----- .../EndSponsoringFutureReservesOperation.java | 4 +-- .../org/stellar/sdk/FeeBumpTransaction.java | 15 +++++------ .../org/stellar/sdk/InflationOperation.java | 6 ++--- src/main/java/org/stellar/sdk/KeyPair.java | 6 ++--- ...iquidityPoolConstantProductParameters.java | 8 +++--- .../sdk/LiquidityPoolDepositOperation.java | 16 ++++++------ .../java/org/stellar/sdk/LiquidityPoolID.java | 4 +-- .../LiquidityPoolShareChangeTrustAsset.java | 4 +-- .../sdk/LiquidityPoolShareTrustLineAsset.java | 4 +-- .../sdk/LiquidityPoolWithdrawOperation.java | 15 +++++------ .../stellar/sdk/ManageBuyOfferOperation.java | 16 ++++++------ .../org/stellar/sdk/ManageDataOperation.java | 8 +++--- .../stellar/sdk/ManageSellOfferOperation.java | 16 ++++++------ src/main/java/org/stellar/sdk/MemoId.java | 4 +-- src/main/java/org/stellar/sdk/Network.java | 4 +-- .../PathPaymentStrictReceiveOperation.java | 16 ++++++------ .../sdk/PathPaymentStrictSendOperation.java | 16 ++++++------ .../org/stellar/sdk/PaymentOperation.java | 12 ++++----- src/main/java/org/stellar/sdk/Predicate.java | 12 ++++----- src/main/java/org/stellar/sdk/Price.java | 4 +-- .../RevokeAccountSponsorshipOperation.java | 8 +++--- ...eClaimableBalanceSponsorshipOperation.java | 8 +++--- .../sdk/RevokeDataSponsorshipOperation.java | 10 +++---- .../sdk/RevokeOfferSponsorshipOperation.java | 10 +++---- .../sdk/RevokeSignerSponsorshipOperation.java | 10 +++---- .../RevokeTrustlineSponsorshipOperation.java | 10 +++---- .../java/org/stellar/sdk/Sep10Challenge.java | 14 +++++----- .../org/stellar/sdk/SetOptionsOperation.java | 26 +++++++++---------- .../sdk/SetTrustlineFlagsOperation.java | 14 +++++----- src/main/java/org/stellar/sdk/TimeBounds.java | 8 +++--- .../java/org/stellar/sdk/Transaction.java | 22 ++++++++-------- .../sdk/responses/LiquidityPoolResponse.java | 6 ++--- .../stellar/sdk/responses/MuxedAccount.java | 10 +++---- .../org/stellar/sdk/responses/TradePrice.java | 8 +++--- ...LiquidityPoolDepositOperationResponse.java | 25 +++++++++--------- ...iquidityPoolWithdrawOperationResponse.java | 14 +++++----- 51 files changed, 265 insertions(+), 264 deletions(-) diff --git a/src/main/java/org/stellar/sdk/Account.java b/src/main/java/org/stellar/sdk/Account.java index 338b5db3c..85a945b92 100644 --- a/src/main/java/org/stellar/sdk/Account.java +++ b/src/main/java/org/stellar/sdk/Account.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Objects; +import java.util.Objects; import lombok.NonNull; /** @@ -56,7 +56,7 @@ public void incrementSequenceNumber() { } public int hashCode() { - return Objects.hashCode(this.mAccountId, this.mSequenceNumber); + return Objects.hash(this.mAccountId, this.mSequenceNumber); } @Override @@ -66,7 +66,7 @@ public boolean equals(Object object) { } Account other = (Account) object; - return Objects.equal(this.mAccountId, other.mAccountId) - && Objects.equal(this.mSequenceNumber, other.mSequenceNumber); + return Objects.equals(this.mAccountId, other.mAccountId) + && Objects.equals(this.mSequenceNumber, other.mSequenceNumber); } } diff --git a/src/main/java/org/stellar/sdk/AccountMergeOperation.java b/src/main/java/org/stellar/sdk/AccountMergeOperation.java index 53409579d..368500b70 100644 --- a/src/main/java/org/stellar/sdk/AccountMergeOperation.java +++ b/src/main/java/org/stellar/sdk/AccountMergeOperation.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Objects; +import java.util.Objects; import lombok.NonNull; import org.stellar.sdk.xdr.Operation.OperationBody; import org.stellar.sdk.xdr.OperationType; @@ -78,7 +78,7 @@ public AccountMergeOperation build() { } public int hashCode() { - return Objects.hashCode(this.destination, this.getSourceAccount()); + return Objects.hash(this.destination, this.getSourceAccount()); } @Override @@ -88,7 +88,7 @@ public boolean equals(Object object) { } AccountMergeOperation other = (AccountMergeOperation) object; - return Objects.equal(this.destination, other.destination) - && Objects.equal(this.getSourceAccount(), other.getSourceAccount()); + return Objects.equals(this.destination, other.destination) + && Objects.equals(this.getSourceAccount(), other.getSourceAccount()); } } diff --git a/src/main/java/org/stellar/sdk/AllowTrustOperation.java b/src/main/java/org/stellar/sdk/AllowTrustOperation.java index e1a79f318..f84bf43ed 100644 --- a/src/main/java/org/stellar/sdk/AllowTrustOperation.java +++ b/src/main/java/org/stellar/sdk/AllowTrustOperation.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Objects; +import java.util.Objects; import lombok.NonNull; import org.stellar.sdk.xdr.*; @@ -167,7 +167,7 @@ public AllowTrustOperation build() { @Override public int hashCode() { - return Objects.hashCode( + return Objects.hash( this.getSourceAccount(), this.assetCode, this.authorize, @@ -182,10 +182,10 @@ public boolean equals(Object object) { } AllowTrustOperation other = (AllowTrustOperation) object; - return Objects.equal(this.assetCode, other.assetCode) - && Objects.equal(this.authorize, other.authorize) - && Objects.equal(this.authorizeToMaintainLiabilities, other.authorizeToMaintainLiabilities) - && Objects.equal(this.trustor, other.trustor) - && Objects.equal(this.getSourceAccount(), other.getSourceAccount()); + return Objects.equals(this.assetCode, other.assetCode) + && Objects.equals(this.authorize, other.authorize) + && Objects.equals(this.authorizeToMaintainLiabilities, other.authorizeToMaintainLiabilities) + && Objects.equals(this.trustor, other.trustor) + && Objects.equals(this.getSourceAccount(), other.getSourceAccount()); } } diff --git a/src/main/java/org/stellar/sdk/AssetAmount.java b/src/main/java/org/stellar/sdk/AssetAmount.java index cfa539632..9c735630a 100644 --- a/src/main/java/org/stellar/sdk/AssetAmount.java +++ b/src/main/java/org/stellar/sdk/AssetAmount.java @@ -1,7 +1,7 @@ package org.stellar.sdk; -import com.google.common.base.Objects; import com.google.gson.annotations.SerializedName; +import java.util.Objects; public final class AssetAmount { @SerializedName("asset") @@ -24,7 +24,7 @@ public String getAmount() { } public int hashCode() { - return Objects.hashCode(asset, amount); + return Objects.hash(asset, amount); } @Override @@ -34,7 +34,7 @@ public boolean equals(Object object) { } AssetAmount o = (AssetAmount) object; - return Objects.equal(this.getAsset(), o.getAsset()) - && Objects.equal(this.getAmount(), o.getAmount()); + return Objects.equals(this.getAsset(), o.getAsset()) + && Objects.equals(this.getAmount(), o.getAmount()); } } diff --git a/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java b/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java index cee0e8333..aa4b799f0 100644 --- a/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java +++ b/src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Objects; +import java.util.Objects; import lombok.NonNull; /** @@ -34,7 +34,7 @@ public String toString() { @Override public int hashCode() { - return Objects.hashCode(this.mCode, this.mIssuer); + return Objects.hash(this.mCode, this.mIssuer); } @Override diff --git a/src/main/java/org/stellar/sdk/AssetTypePoolShare.java b/src/main/java/org/stellar/sdk/AssetTypePoolShare.java index da9dd4436..d5293a512 100644 --- a/src/main/java/org/stellar/sdk/AssetTypePoolShare.java +++ b/src/main/java/org/stellar/sdk/AssetTypePoolShare.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.base.Objects; +import java.util.Objects; /** * Represents Stellar liquidity pool share asset - Date: Mon, 11 Sep 2023 15:53:51 +0800 Subject: [PATCH 04/20] Use `String.join` instead of `com.google.common.base.Joiner` --- .../org/stellar/sdk/requests/OperationsRequestBuilder.java | 3 +-- .../java/org/stellar/sdk/requests/PaymentsRequestBuilder.java | 3 +-- src/main/java/org/stellar/sdk/requests/RequestBuilder.java | 3 +-- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java index bca03692f..efc159aad 100644 --- a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java @@ -1,6 +1,5 @@ package org.stellar.sdk.requests; -import com.google.common.base.Joiner; import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; @@ -158,7 +157,7 @@ protected void updateToJoin(String value, boolean include) { if (toJoin.isEmpty()) { uriBuilder.removeAllQueryParameters("join"); } else { - uriBuilder.setQueryParameter("join", Joiner.on(",").join(toJoin)); + uriBuilder.setQueryParameter("join", String.join(",", toJoin)); } } diff --git a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java index 83dc532fe..823597231 100644 --- a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java @@ -1,6 +1,5 @@ package org.stellar.sdk.requests; -import com.google.common.base.Joiner; import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; @@ -78,7 +77,7 @@ protected void updateToJoin(String value, boolean include) { if (toJoin.isEmpty()) { uriBuilder.removeAllQueryParameters("join"); } else { - uriBuilder.setQueryParameter("join", Joiner.on(",").join(toJoin)); + uriBuilder.setQueryParameter("join", String.join(",", toJoin)); } } diff --git a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java index a935bef0d..a108c4a6c 100644 --- a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java @@ -1,6 +1,5 @@ package org.stellar.sdk.requests; -import com.google.common.base.Joiner; import com.google.common.collect.Lists; import java.util.ArrayList; import java.util.Arrays; @@ -87,7 +86,7 @@ public RequestBuilder setAssetsParameter(String name, List assets) { for (Asset asset : assets) { assetStrings.add(encodeAsset(asset)); } - uriBuilder.setQueryParameter(name, Joiner.on(",").join(assetStrings)); + uriBuilder.setQueryParameter(name, String.join(",", assetStrings)); return this; } From e76c0ed63b578e8407f802038910a266c0218109 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 16:15:12 +0800 Subject: [PATCH 05/20] Remove the use of `com.google.common.collect.Lists`. --- .../stellar/sdk/CreateClaimableBalanceOperation.java | 4 ++-- src/main/java/org/stellar/sdk/FeeBumpTransaction.java | 5 ++--- src/main/java/org/stellar/sdk/Predicate.java | 4 ++-- .../java/org/stellar/sdk/requests/RequestBuilder.java | 3 +-- .../stellar/sdk/responses/PredicateDeserializer.java | 6 +++--- .../java/org/stellar/sdk/ClaimableBalanceIdTest.java | 6 +++--- src/test/java/org/stellar/sdk/OperationTest.java | 7 +++---- .../stellar/sdk/requests/PathsRequestBuilderTest.java | 10 +++++----- .../sdk/responses/OperationDeserializerTest.java | 11 ++++++----- 9 files changed, 27 insertions(+), 29 deletions(-) diff --git a/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java index 53738fd79..50f0bcc36 100644 --- a/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/CreateClaimableBalanceOperation.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.collect.Lists; +import java.util.ArrayList; import java.util.List; import java.util.Objects; import lombok.NonNull; @@ -80,7 +80,7 @@ public static class Builder { Builder(CreateClaimableBalanceOp op) { asset = Asset.fromXdr(op.getAsset()); amount = Operation.fromXdrAmount(op.getAmount().getInt64().longValue()); - claimants = Lists.newArrayList(); + claimants = new ArrayList<>(); for (org.stellar.sdk.xdr.Claimant c : op.getClaimants()) { claimants.add( new Claimant( diff --git a/src/main/java/org/stellar/sdk/FeeBumpTransaction.java b/src/main/java/org/stellar/sdk/FeeBumpTransaction.java index 0a9fa7f4f..28f4cd38b 100644 --- a/src/main/java/org/stellar/sdk/FeeBumpTransaction.java +++ b/src/main/java/org/stellar/sdk/FeeBumpTransaction.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import com.google.common.collect.Lists; +import java.util.ArrayList; import java.util.Arrays; import java.util.Objects; import lombok.NonNull; @@ -138,8 +138,7 @@ public Builder(@NonNull AccountConverter accountConverter, @NonNull final Transa .timeBounds(inner.getTimeBounds()) .build()) .build(); - - this.mInner.mSignatures = Lists.newArrayList(inner.mSignatures); + this.mInner.mSignatures = new ArrayList<>(inner.mSignatures); } else { this.mInner = inner; } diff --git a/src/main/java/org/stellar/sdk/Predicate.java b/src/main/java/org/stellar/sdk/Predicate.java index 94f8f0e4c..fd3a5b0bf 100644 --- a/src/main/java/org/stellar/sdk/Predicate.java +++ b/src/main/java/org/stellar/sdk/Predicate.java @@ -1,7 +1,7 @@ package org.stellar.sdk; -import com.google.common.collect.Lists; import java.math.BigInteger; +import java.util.ArrayList; import java.util.List; import java.util.Objects; import org.stellar.sdk.xdr.ClaimPredicate; @@ -16,7 +16,7 @@ public abstract class Predicate { private static List convertXDRPredicates(ClaimPredicate[] predicates) { - List list = Lists.newArrayList(); + List list = new ArrayList<>(); for (ClaimPredicate p : predicates) { list.add(fromXdr(p)); } diff --git a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java index a108c4a6c..0bfadc7ab 100644 --- a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java @@ -1,6 +1,5 @@ package org.stellar.sdk.requests; -import com.google.common.collect.Lists; import java.util.ArrayList; import java.util.Arrays; import java.util.List; @@ -82,7 +81,7 @@ public RequestBuilder order(Order direction) { * @param assets the list of assets to be serialized into the query parameter value */ public RequestBuilder setAssetsParameter(String name, List assets) { - List assetStrings = Lists.newArrayList(); + List assetStrings = new ArrayList<>(); for (Asset asset : assets) { assetStrings.add(encodeAsset(asset)); } diff --git a/src/main/java/org/stellar/sdk/responses/PredicateDeserializer.java b/src/main/java/org/stellar/sdk/responses/PredicateDeserializer.java index 27fe89086..e341f4dfb 100644 --- a/src/main/java/org/stellar/sdk/responses/PredicateDeserializer.java +++ b/src/main/java/org/stellar/sdk/responses/PredicateDeserializer.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses; -import com.google.common.collect.Lists; import com.google.gson.*; import java.lang.reflect.Type; +import java.util.ArrayList; import java.util.List; import org.stellar.sdk.Predicate; import org.stellar.sdk.xdr.Duration; @@ -25,7 +25,7 @@ public Predicate deserialize(JsonElement json, Type typeOfT, JsonDeserialization } if (obj.has("and")) { - List inner = Lists.newArrayList(); + List inner = new ArrayList<>(); for (JsonElement elt : obj.get("and").getAsJsonArray()) { inner.add(deserialize(elt, typeOfT, context)); } @@ -33,7 +33,7 @@ public Predicate deserialize(JsonElement json, Type typeOfT, JsonDeserialization } if (obj.has("or")) { - List inner = Lists.newArrayList(); + List inner = new ArrayList<>(); for (JsonElement elt : obj.get("or").getAsJsonArray()) { inner.add(deserialize(elt, typeOfT, context)); } diff --git a/src/test/java/org/stellar/sdk/ClaimableBalanceIdTest.java b/src/test/java/org/stellar/sdk/ClaimableBalanceIdTest.java index d9484965c..c8de442a8 100644 --- a/src/test/java/org/stellar/sdk/ClaimableBalanceIdTest.java +++ b/src/test/java/org/stellar/sdk/ClaimableBalanceIdTest.java @@ -3,8 +3,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; -import com.google.common.collect.Lists; import java.io.IOException; +import java.util.Collections; import org.junit.Test; import org.stellar.sdk.xdr.CryptoKeyType; import org.stellar.sdk.xdr.MuxedAccount; @@ -22,7 +22,7 @@ public void testClaimableBalanceIds() throws IOException { new CreateClaimableBalanceOperation.Builder( "420", new AssetTypeNative(), - Lists.newArrayList( + Collections.singletonList( new Claimant( "GCACCFMIWJAHUUASSE2WC7V6VVDLYRLSJYZ3DJEXCG523FSHTNII6KOG", new Predicate.Unconditional()))) @@ -52,7 +52,7 @@ public void testClaimableBalanceIds() throws IOException { new CreateClaimableBalanceOperation.Builder( "420", new AssetTypeNative(), - Lists.newArrayList( + Collections.singletonList( new Claimant( "GCACCFMIWJAHUUASSE2WC7V6VVDLYRLSJYZ3DJEXCG523FSHTNII6KOG", new Predicate.Unconditional()))) diff --git a/src/test/java/org/stellar/sdk/OperationTest.java b/src/test/java/org/stellar/sdk/OperationTest.java index d34b684fb..4ec137b01 100644 --- a/src/test/java/org/stellar/sdk/OperationTest.java +++ b/src/test/java/org/stellar/sdk/OperationTest.java @@ -1,11 +1,11 @@ package org.stellar.sdk; +import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; import static org.stellar.sdk.Asset.create; -import com.google.common.collect.Lists; import com.google.common.io.BaseEncoding; import java.io.ByteArrayInputStream; import java.io.IOException; @@ -161,8 +161,7 @@ public void testPathPaymentStrictReceiveOperation() assertEquals(sendMax, parsedOperation.getSendMax()); assertTrue(parsedOperation.getDestAsset() instanceof AssetTypeCreditAlphaNum4); assertEquals(destAmount, parsedOperation.getDestAmount()); - assertEquals(Lists.newArrayList(path), Lists.newArrayList(parsedOperation.getPath())); - + assertArrayEquals(path, parsedOperation.getPath()); assertEquals( "AAAAAQAAAAC7JAuE3XvquOnbsgv2SRztjuk4RoBVefQ0rlrFMMQvfAAAAAIAAAAAAAAAAAAAA+gAAAAA7eBSYbzcL5UKo7oXO24y1ckX+XuCtkDsyNHOp1n1bxAAAAABVVNEAAAAAACNlYd30HdCuLI54eyYjyX/fDyH9IJWIr/hKDcXKQbq1QAAAAAAAAPoAAAAAgAAAAFVU0QAAAAAACoIKnpnw8rtrfxa276dFZo1C19mDqWXtG4ufhWrLUd1AAAAAlRFU1RURVNUAAAAAAAAAABE/ttVl8BLV0csW/xgXtbXOVf1lMyDluMiafl0IDVFIg==", operation.toXdrBase64(AccountConverter.enableMuxed())); @@ -302,7 +301,7 @@ public void testPathPaymentStrictSendOperation() assertEquals(sendAmount, parsedOperation.getSendAmount()); assertTrue(parsedOperation.getDestAsset() instanceof AssetTypeCreditAlphaNum4); assertEquals(destMin, parsedOperation.getDestMin()); - assertEquals(Lists.newArrayList(path), Lists.newArrayList(parsedOperation.getPath())); + assertArrayEquals(path, parsedOperation.getPath()); assertEquals( "AAAAAQAAAAC7JAuE3XvquOnbsgv2SRztjuk4RoBVefQ0rlrFMMQvfAAAAA0AAAAAAAAAAAAAA+gAAAAA7eBSYbzcL5UKo7oXO24y1ckX+XuCtkDsyNHOp1n1bxAAAAABVVNEAAAAAACNlYd30HdCuLI54eyYjyX/fDyH9IJWIr/hKDcXKQbq1QAAAAAAACMoAAAAAgAAAAFVU0QAAAAAACoIKnpnw8rtrfxa276dFZo1C19mDqWXtG4ufhWrLUd1AAAAAlRFU1RURVNUAAAAAAAAAABE/ttVl8BLV0csW/xgXtbXOVf1lMyDluMiafl0IDVFIg==", diff --git a/src/test/java/org/stellar/sdk/requests/PathsRequestBuilderTest.java b/src/test/java/org/stellar/sdk/requests/PathsRequestBuilderTest.java index 94c4a766c..a2ad1408f 100644 --- a/src/test/java/org/stellar/sdk/requests/PathsRequestBuilderTest.java +++ b/src/test/java/org/stellar/sdk/requests/PathsRequestBuilderTest.java @@ -5,7 +5,7 @@ import static org.junit.Assert.fail; import static org.stellar.sdk.Asset.create; -import com.google.common.collect.Lists; +import java.util.Arrays; import java.util.List; import okhttp3.HttpUrl; import org.junit.Test; @@ -46,7 +46,7 @@ public void testStrictReceiveWithSourceAccount() { @Test public void testStrictReceiveWithSourceAssets() { List assets = - Lists.newArrayList( + Arrays.asList( create("native", "", ""), create( "credit_alphanum4", @@ -87,7 +87,7 @@ public void testStrictReceiveWithSourceAssets() { @Test public void testStrictReceiveWithSourceAccountAndSourceAssets() { List assets = - Lists.newArrayList( + Arrays.asList( create("native", "", ""), create( "credit_alphanum4", @@ -151,7 +151,7 @@ public void testStrictSendWithDestinationAccount() { @Test public void testStrictSendWithDestinationAssets() { List assets = - Lists.newArrayList( + Arrays.asList( create("native", "", ""), create( "credit_alphanum4", @@ -190,7 +190,7 @@ public void testStrictSendWithDestinationAssets() { @Test public void testStrictSendWithDestinationAccountAndDestinationAssets() { List assets = - Lists.newArrayList( + Arrays.asList( create("native", "", ""), create( "credit_alphanum4", diff --git a/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java index 52723ab03..49e39ff40 100644 --- a/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java @@ -4,9 +4,9 @@ import static org.stellar.sdk.Asset.create; import com.google.common.collect.ImmutableList; -import com.google.common.collect.Lists; import java.math.BigInteger; import java.util.Arrays; +import java.util.Collections; import junit.framework.TestCase; import org.junit.Test; import org.stellar.sdk.Asset; @@ -1587,11 +1587,12 @@ public void testDeserializeSetTrustlineFlagsOperation() { operation.getAssetIssuer(), "GCWVFBJ24754I5GXG4JOEB72GJCL3MKWC7VAEYWKGQHPVH3ENPNBSKWS"); assertEquals(operation.getAssetCode(), "EUR"); assertEquals(operation.getAssetType(), "credit_alphanum4"); - assertEquals(operation.getSetFlags(), Lists.newArrayList(4)); - assertEquals(operation.getClearFlags(), Lists.newArrayList(2)); - assertEquals(operation.getSetFlagStrings(), Lists.newArrayList("clawback_enabled")); + assertEquals(operation.getSetFlags(), Collections.singletonList(4)); + assertEquals(operation.getClearFlags(), Collections.singletonList(2)); + assertEquals(operation.getSetFlagStrings(), Collections.singletonList("clawback_enabled")); assertEquals( - operation.getClearFlagStrings(), Lists.newArrayList("authorized_to_maintain_liabilites")); + operation.getClearFlagStrings(), + Collections.singletonList("authorized_to_maintain_liabilites")); } @Test From 6d34991b72cc61e66a7bf6c0a3151eb7f903f5ca Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 16:40:00 +0800 Subject: [PATCH 06/20] Remove the use of `com.google.common.collect.ImmutableList`. --- .../org/stellar/sdk/AbstractTransaction.java | 4 +-- .../stellar/sdk/responses/GsonSingleton.java | 2 -- .../responses/ImmutableListDeserializer.java | 25 ------------------- .../sdk/responses/OperationDeserializer.java | 2 -- .../InvokeHostFunctionOperationResponse.java | 14 +++++------ .../PathPaymentBaseOperationResponse.java | 3 +-- .../sorobanrpc/GetEventsResponse.java | 6 ++--- .../sorobanrpc/GetLedgerEntriesResponse.java | 4 +-- .../SimulateTransactionResponse.java | 8 +++--- .../org/stellar/sdk/Sep10ChallengeTest.java | 3 +-- .../org/stellar/sdk/SorobanServerTest.java | 8 +++--- .../responses/OperationDeserializerTest.java | 8 +++--- .../TransactionDeserializerTest.java | 11 ++++---- 13 files changed, 32 insertions(+), 66 deletions(-) delete mode 100644 src/main/java/org/stellar/sdk/responses/ImmutableListDeserializer.java diff --git a/src/main/java/org/stellar/sdk/AbstractTransaction.java b/src/main/java/org/stellar/sdk/AbstractTransaction.java index 8be33931d..79786e15e 100644 --- a/src/main/java/org/stellar/sdk/AbstractTransaction.java +++ b/src/main/java/org/stellar/sdk/AbstractTransaction.java @@ -1,10 +1,10 @@ package org.stellar.sdk; -import com.google.common.collect.ImmutableList; import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; +import java.util.Collections; import java.util.List; import lombok.NonNull; import org.stellar.sdk.xdr.DecoratedSignature; @@ -94,7 +94,7 @@ public AccountConverter getAccountConverter() { * @return immutable list of signatures */ public List getSignatures() { - return ImmutableList.copyOf(mSignatures); + return Collections.unmodifiableList(mSignatures); } /** diff --git a/src/main/java/org/stellar/sdk/responses/GsonSingleton.java b/src/main/java/org/stellar/sdk/responses/GsonSingleton.java index c357e0bab..2a717c2d3 100644 --- a/src/main/java/org/stellar/sdk/responses/GsonSingleton.java +++ b/src/main/java/org/stellar/sdk/responses/GsonSingleton.java @@ -1,6 +1,5 @@ package org.stellar.sdk.responses; -import com.google.common.collect.ImmutableList; import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.reflect.TypeToken; @@ -69,7 +68,6 @@ public static Gson getInstance() { .registerTypeAdapter( claimableBalancePageType.getType(), new PageDeserializer(claimableBalancePageType)) - .registerTypeAdapter(ImmutableList.class, new ImmutableListDeserializer()) .create(); } return instance; diff --git a/src/main/java/org/stellar/sdk/responses/ImmutableListDeserializer.java b/src/main/java/org/stellar/sdk/responses/ImmutableListDeserializer.java deleted file mode 100644 index 00aee6d21..000000000 --- a/src/main/java/org/stellar/sdk/responses/ImmutableListDeserializer.java +++ /dev/null @@ -1,25 +0,0 @@ -package org.stellar.sdk.responses; - -import com.google.common.collect.ImmutableList; -import com.google.common.reflect.TypeToken; -import com.google.gson.JsonDeserializationContext; -import com.google.gson.JsonDeserializer; -import com.google.gson.JsonElement; -import com.google.gson.JsonParseException; -import java.lang.reflect.Type; -import java.util.List; - -public class ImmutableListDeserializer implements JsonDeserializer> { - - @Override - public ImmutableList deserialize( - JsonElement json, Type type, JsonDeserializationContext context) throws JsonParseException { - @SuppressWarnings("unchecked") - final TypeToken> immutableListToken = - (TypeToken>) TypeToken.of(type); - final TypeToken> listToken = - immutableListToken.getSupertype(List.class); - final List list = context.deserialize(json, listToken.getType()); - return ImmutableList.copyOf(list); - } -} diff --git a/src/main/java/org/stellar/sdk/responses/OperationDeserializer.java b/src/main/java/org/stellar/sdk/responses/OperationDeserializer.java index 550cad8ab..42e48c2bc 100644 --- a/src/main/java/org/stellar/sdk/responses/OperationDeserializer.java +++ b/src/main/java/org/stellar/sdk/responses/OperationDeserializer.java @@ -1,6 +1,5 @@ package org.stellar.sdk.responses; -import com.google.common.collect.ImmutableList; import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.JsonDeserializationContext; @@ -28,7 +27,6 @@ public OperationResponse deserialize( .registerTypeAdapter(Asset.class, new AssetDeserializer()) .registerTypeAdapter(Predicate.class, new PredicateDeserializer()) .registerTypeAdapter(TransactionResponse.class, new TransactionDeserializer()) - .registerTypeAdapter(ImmutableList.class, new ImmutableListDeserializer()) .registerTypeAdapter(LiquidityPoolID.class, new LiquidityPoolIDDeserializer()) .registerTypeAdapter(LiquidityPoolType.class, new LiquidityPoolTypeDeserializer()) .create(); diff --git a/src/main/java/org/stellar/sdk/responses/operations/InvokeHostFunctionOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/InvokeHostFunctionOperationResponse.java index 45764b231..298bec1c3 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/InvokeHostFunctionOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/InvokeHostFunctionOperationResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses.operations; -import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; +import java.util.List; import org.stellar.sdk.xdr.HostFunctionType; /** @@ -20,7 +20,7 @@ public class InvokeHostFunctionOperationResponse extends OperationResponse { private final String function; @SerializedName("parameters") - private final ImmutableList parameters; + private final List parameters; @SerializedName("address") private final String address; @@ -29,14 +29,14 @@ public class InvokeHostFunctionOperationResponse extends OperationResponse { private final String salt; @SerializedName("asset_balance_changes") - private final ImmutableList assetBalanceChanges; + private final List assetBalanceChanges; public InvokeHostFunctionOperationResponse( String function, - ImmutableList parameters, + List parameters, String address, String salt, - ImmutableList assetBalanceChanges) { + List assetBalanceChanges) { this.function = function; this.parameters = parameters; this.address = address; @@ -60,7 +60,7 @@ public String getFunction() { return function; } - public ImmutableList getParameters() { + public List getParameters() { return parameters; } @@ -72,7 +72,7 @@ public String getSalt() { return salt; } - public ImmutableList getAssetBalanceChanges() { + public List getAssetBalanceChanges() { return assetBalanceChanges; } diff --git a/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java index 09e7b8d25..e91e24563 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/PathPaymentBaseOperationResponse.java @@ -2,7 +2,6 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; import java.util.List; @@ -55,7 +54,7 @@ public abstract class PathPaymentBaseOperationResponse extends OperationResponse private String sourceAssetIssuer; @SerializedName("path") - private ImmutableList path; + private List path; public String getAmount() { return amount; diff --git a/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetEventsResponse.java b/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetEventsResponse.java index 890b94b65..0dbd2cbf4 100644 --- a/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetEventsResponse.java +++ b/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetEventsResponse.java @@ -1,6 +1,6 @@ package org.stellar.sdk.responses.sorobanrpc; -import com.google.common.collect.ImmutableList; +import java.util.List; import lombok.AllArgsConstructor; import lombok.Value; import org.stellar.sdk.requests.sorobanrpc.EventFilterType; @@ -14,7 +14,7 @@ @AllArgsConstructor @Value public class GetEventsResponse { - ImmutableList events; + List events; Long latestLedger; @@ -33,7 +33,7 @@ public static class EventInfo { String pagingToken; - ImmutableList topic; + List topic; EventInfoValue value; diff --git a/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetLedgerEntriesResponse.java b/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetLedgerEntriesResponse.java index 96015fdd5..4fc8dfbb3 100644 --- a/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetLedgerEntriesResponse.java +++ b/src/main/java/org/stellar/sdk/responses/sorobanrpc/GetLedgerEntriesResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses.sorobanrpc; -import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; +import java.util.List; import lombok.AllArgsConstructor; import lombok.Value; @@ -14,7 +14,7 @@ @AllArgsConstructor @Value public class GetLedgerEntriesResponse { - ImmutableList entries; + List entries; Long latestLedger; diff --git a/src/main/java/org/stellar/sdk/responses/sorobanrpc/SimulateTransactionResponse.java b/src/main/java/org/stellar/sdk/responses/sorobanrpc/SimulateTransactionResponse.java index 0fb1b80f8..b7d64850f 100644 --- a/src/main/java/org/stellar/sdk/responses/sorobanrpc/SimulateTransactionResponse.java +++ b/src/main/java/org/stellar/sdk/responses/sorobanrpc/SimulateTransactionResponse.java @@ -1,8 +1,8 @@ package org.stellar.sdk.responses.sorobanrpc; -import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; import java.math.BigInteger; +import java.util.List; import lombok.AllArgsConstructor; import lombok.Value; @@ -19,11 +19,11 @@ public class SimulateTransactionResponse { String transactionData; - ImmutableList events; + List events; Long minResourceFee; - ImmutableList results; + List results; SimulateTransactionCost cost; @@ -32,7 +32,7 @@ public class SimulateTransactionResponse { @AllArgsConstructor @Value public static class SimulateHostFunctionResult { - ImmutableList auth; + List auth; String xdr; } diff --git a/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java b/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java index 3e61df922..787d8db74 100644 --- a/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java +++ b/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java @@ -5,7 +5,6 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.collect.ImmutableList; import com.google.common.io.BaseEncoding; import java.io.IOException; import java.security.SecureRandom; @@ -151,7 +150,7 @@ public void testReadChallengeTransactionAcceptsBothV0AndV1() assertEquals(v0ChallengeTransaction, v1ChallengeTransaction); - for (String envelopeBase64 : ImmutableList.of(v0Base64, v1Base64)) { + for (String envelopeBase64 : Arrays.asList(v0Base64, v1Base64)) { Sep10Challenge.ChallengeTransaction challengeTransaction = Sep10Challenge.readChallengeTransaction( envelopeBase64, server.getAccountId(), Network.TESTNET, domainName, webAuthDomain); diff --git a/src/test/java/org/stellar/sdk/SorobanServerTest.java b/src/test/java/org/stellar/sdk/SorobanServerTest.java index 572c1f68a..379aef26e 100644 --- a/src/test/java/org/stellar/sdk/SorobanServerTest.java +++ b/src/test/java/org/stellar/sdk/SorobanServerTest.java @@ -428,16 +428,16 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) assertEquals(resp.getLatestLedger().longValue(), 7943L); assertEquals(resp.getEntries().size(), 2); assertEquals( - resp.getEntries().asList().get(0).getKey(), + resp.getEntries().get(0).getKey(), "AAAAAAAAAACynni6I2ACEzWuORVM1b2y0k1ZDni0W6JlC/Ad/mfCSg=="); assertEquals( - resp.getEntries().asList().get(0).getXdr(), + resp.getEntries().get(0).getXdr(), "AAAAAAAAAACynni6I2ACEzWuORVM1b2y0k1ZDni0W6JlC/Ad/mfCSgAAABdIdugAAAAAnwAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAA"); assertEquals( - resp.getEntries().asList().get(1).getKey(), + resp.getEntries().get(1).getKey(), "AAAAAAAAAADBPp7TMinJylnn+6dQXJACNc15LF+aJ2Py1BaR4P10JA=="); assertEquals( - resp.getEntries().asList().get(1).getXdr(), + resp.getEntries().get(1).getXdr(), "AAAAAAAAAADBPp7TMinJylnn+6dQXJACNc15LF+aJ2Py1BaR4P10JAAAABdIcmH6AAAAoQAAAAgAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAAAAAAAAAAAAAADAAAAAAAAHAkAAAAAZMPQ0g=="); server.close(); mockWebServer.close(); diff --git a/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java index 49e39ff40..cd7c46274 100644 --- a/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/OperationDeserializerTest.java @@ -3,13 +3,11 @@ import static java.math.BigInteger.valueOf; import static org.stellar.sdk.Asset.create; -import com.google.common.collect.ImmutableList; import java.math.BigInteger; import java.util.Arrays; import java.util.Collections; import junit.framework.TestCase; import org.junit.Test; -import org.stellar.sdk.Asset; import org.stellar.sdk.AssetAmount; import org.stellar.sdk.AssetTypeNative; import org.stellar.sdk.AssetTypePoolShare; @@ -871,7 +869,7 @@ public void testDeserializePathPaymentOperation() { assertEquals(operation.getAsset(), new AssetTypeNative()); assertEquals( operation.getPath(), - ImmutableList.of( + Arrays.asList( new AssetTypeNative(), create(null, "CNY", "GAREELUB43IRHWEASCFBLKHURCGMHE5IF6XSE7EXDLACYHGRHM43RFOX"), create(null, "CNYMNL", "GAREELUB43IRHWEASCFBLKHURCGMHE5IF6XSE7EXDLACYHGRHM43RFOX"))); @@ -935,7 +933,7 @@ public void testDeserializePathPaymentStrictSendOperation() { assertEquals(operation.getAsset(), new AssetTypeNative()); assertEquals( operation.getPath(), - ImmutableList.of( + Arrays.asList( new AssetTypeNative(), create(null, "CNY", "GAREELUB43IRHWEASCFBLKHURCGMHE5IF6XSE7EXDLACYHGRHM43RFOX"), create(null, "CNYMNL", "GAREELUB43IRHWEASCFBLKHURCGMHE5IF6XSE7EXDLACYHGRHM43RFOX"))); @@ -1058,7 +1056,7 @@ public void testDeserializePathPaymentOperationSourceAssetNative() { assertEquals(operation.getAmount(), "2.5000000"); assertEquals(operation.getSourceMax(), "1.1779523"); assertEquals(operation.getSourceAsset(), new AssetTypeNative()); - assertEquals(operation.getPath(), ImmutableList.of()); + assertEquals(operation.getPath(), Collections.emptyList()); assertEquals( operation.getAsset(), create(null, "XRP", "GBVOL67TMUQBGL4TZYNMY3ZQ5WGQYFPFD5VJRWXR72VA33VFNL225PL5")); diff --git a/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java b/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java index dd1e86011..0dc88025a 100644 --- a/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java +++ b/src/test/java/org/stellar/sdk/responses/TransactionDeserializerTest.java @@ -1,10 +1,9 @@ package org.stellar.sdk.responses; import static java.math.BigInteger.valueOf; -import static org.junit.Assert.assertEquals; -import com.google.common.collect.ImmutableList; import java.util.Arrays; +import java.util.Collections; import java.util.Optional; import junit.framework.TestCase; import org.junit.Test; @@ -28,20 +27,20 @@ public void testDeserializeFeeBump() { assertEquals(transaction.getMaxFee(), Long.valueOf(776)); assertEquals(transaction.getFeeCharged(), Long.valueOf(123)); assertEquals(transaction.getOperationCount(), Integer.valueOf(1)); - assertEquals(transaction.getSignatures(), ImmutableList.of("Hh4e")); + assertEquals(transaction.getSignatures(), Collections.singletonList("Hh4e")); TransactionResponse.FeeBumpTransaction feeBumpTransaction = transaction.getFeeBump().get(); assertEquals( feeBumpTransaction.getHash(), "3dfef7d7226995b504f2827cc63d45ad41e9687bb0a8abcf08ba755fedca0352"); - assertEquals(feeBumpTransaction.getSignatures(), ImmutableList.of("Hh4e")); + assertEquals(feeBumpTransaction.getSignatures(), Collections.singletonList("Hh4e")); TransactionResponse.InnerTransaction innerTransaction = transaction.getInner().get(); assertEquals( innerTransaction.getHash(), "e98869bba8bce08c10b78406202127f3888c25454cd37b02600862452751f526"); assertEquals(innerTransaction.getMaxFee(), Long.valueOf(99)); - assertEquals(innerTransaction.getSignatures(), ImmutableList.of("FBQU")); + assertEquals(innerTransaction.getSignatures(), Collections.singletonList("FBQU")); assertFalse(transaction.getSourceAccountMuxed().isPresent()); assertFalse(transaction.getFeeAccountMuxed().isPresent()); @@ -74,7 +73,7 @@ public void testDeserialize() { "AAAAAAAAAAEAAAACAAAAAAAN+SAAAAAAAAAAAMDtGdqtLMLCPc5P4zZu0IwWlUF2rElL5KvTSoGO0W/uAAAAAEsKz9AADfkgAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAQAN+SAAAAAAAAAAAP1qe44j+i4uIT+arbD4QDQBt8ryEeJd7a0jskQ3nwDeAAHp6WMr55YACD1BAAAAHgAAAAoAAAAAAAAAAAAAAAABAAAAAAAACgAAAAARC07BokpLTOF+/vVKBwiAlop7hHGJTNeGGlY4MoPykwAAAAEAAAAAK+Lzfd3yDD+Ov0GbYu1g7SaIBrKZeBUxoCunkLuI7aoAAAABAAAAAERmsKL73CyLV/HvjyQCERDXXpWE70Xhyb6MR5qPO3yQAAAAAQAAAABSORGwAdyuanN3sNOHqNSpACyYdkUM3L8VafUu69EvEgAAAAEAAAAAeCzqJNkMM/jLvyuMIfyFHljBlLCtDyj17RMycPuNtRMAAAABAAAAAIEi4R7juq15ymL00DNlAddunyFT4FyUD4muC4t3bobdAAAAAQAAAACaNpLL5YMfjOTdXVEqrAh99LM12sN6He6pHgCRAa1f1QAAAAEAAAAAqB+lfAPV9ak+Zkv4aTNZwGaFFAfui4+yhM3dGhoYJ+sAAAABAAAAAMNJrEvdMg6M+M+n4BDIdzsVSj/ZI9SvAp7mOOsvAD/WAAAAAQAAAADbHA6xiKB1+G79mVqpsHMOleOqKa5mxDpP5KEp/Xdz9wAAAAEAAAAAAAAAAA=="); assertEquals( transaction.getSignatures(), - ImmutableList.of( + Collections.singletonList( "b/noKPYnxb8oJmv6gLixY0PUJMZZ9pxwc226JtAfyRkhv6oFINj3iDuGJoBeuUh6D1vujP9e4/fH0xZjDaO3Aw==")); assertEquals(transaction.getFeeBump(), Optional.empty()); assertEquals(transaction.getInner(), Optional.empty()); From 7932cc037131ec791935d2c13bbf0845ddc4004d Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 16:57:50 +0800 Subject: [PATCH 07/20] Remove the use of `com.google.common.collect.*`. --- .../java/org/stellar/sdk/Sep10Challenge.java | 20 +++++++++++-------- .../requests/OperationsRequestBuilder.java | 4 ++-- .../sdk/requests/PaymentsRequestBuilder.java | 4 ++-- 3 files changed, 16 insertions(+), 12 deletions(-) diff --git a/src/main/java/org/stellar/sdk/Sep10Challenge.java b/src/main/java/org/stellar/sdk/Sep10Challenge.java index 9dbd5be3a..36e1f45dc 100644 --- a/src/main/java/org/stellar/sdk/Sep10Challenge.java +++ b/src/main/java/org/stellar/sdk/Sep10Challenge.java @@ -1,15 +1,15 @@ package org.stellar.sdk; -import com.google.common.collect.HashMultimap; -import com.google.common.collect.Multimap; import com.google.common.io.BaseEncoding; import java.io.IOException; import java.math.BigInteger; import java.security.SecureRandom; +import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; +import java.util.List; import java.util.Map; import java.util.Objects; import java.util.Optional; @@ -681,10 +681,14 @@ private static Set verifyTransactionSignatures( byte[] txHash = transaction.hash(); // find and verify signatures - Set signersFound = new HashSet(); - Multimap signatures = HashMultimap.create(); + Set signersFound = new HashSet<>(); + Map> signatures = new HashMap<>(); + for (DecoratedSignature decoratedSignature : transaction.getSignatures()) { - signatures.put(decoratedSignature.getHint(), decoratedSignature.getSignature()); + SignatureHint hint = decoratedSignature.getHint(); + Signature signature = decoratedSignature.getSignature(); + List signatureList = signatures.computeIfAbsent(hint, k -> new ArrayList<>()); + signatureList.add(signature); } for (String signer : signers) { @@ -695,13 +699,13 @@ private static Set verifyTransactionSignatures( continue; } SignatureHint hint = keyPair.getSignatureHint(); - - for (Signature signature : signatures.get(hint)) { + List signatureList = signatures.getOrDefault(hint, Collections.emptyList()); + for (Signature signature : signatureList) { if (keyPair.verify(txHash, signature.getSignature())) { signersFound.add(signer); // explicitly ensure that a transaction signature cannot be // mapped to more than one signer - signatures.remove(hint, signature); + signatureList.remove(signature); break; } } diff --git a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java index efc159aad..4128b4d80 100644 --- a/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/OperationsRequestBuilder.java @@ -1,8 +1,8 @@ package org.stellar.sdk.requests; -import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; +import java.util.HashSet; import java.util.Set; import lombok.NonNull; import okhttp3.HttpUrl; @@ -19,7 +19,7 @@ public class OperationsRequestBuilder extends RequestBuilder { public OperationsRequestBuilder(OkHttpClient httpClient, HttpUrl serverURI) { super(httpClient, serverURI, "operations"); - toJoin = Sets.newHashSet(); + toJoin = new HashSet<>(); } /** diff --git a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java index 823597231..a5dd26608 100644 --- a/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/PaymentsRequestBuilder.java @@ -1,8 +1,8 @@ package org.stellar.sdk.requests; -import com.google.common.collect.Sets; import com.google.gson.reflect.TypeToken; import java.io.IOException; +import java.util.HashSet; import java.util.Set; import lombok.NonNull; import okhttp3.HttpUrl; @@ -18,7 +18,7 @@ public class PaymentsRequestBuilder extends RequestBuilder { public PaymentsRequestBuilder(OkHttpClient httpClient, HttpUrl serverURI) { super(httpClient, serverURI, "payments"); - toJoin = Sets.newHashSet(); + toJoin = new HashSet<>(); } /** From ad5cb6e993799f25889718a8d8b67bca7032e9a1 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 17:12:40 +0800 Subject: [PATCH 08/20] Remove the use of `com.google.common.base.Function` and `com.google.common.primitives.Bytes`. --- src/main/java/org/stellar/sdk/StrKey.java | 6 +++-- .../org/stellar/sdk/TransactionBuilder.java | 6 ++--- .../sdk/responses/AssetDeserializer.java | 25 +++++-------------- src/test/java/org/stellar/sdk/MemoTest.java | 6 ++--- 4 files changed, 16 insertions(+), 27 deletions(-) diff --git a/src/main/java/org/stellar/sdk/StrKey.java b/src/main/java/org/stellar/sdk/StrKey.java index e86795b42..b8d71e6ff 100644 --- a/src/main/java/org/stellar/sdk/StrKey.java +++ b/src/main/java/org/stellar/sdk/StrKey.java @@ -1,7 +1,6 @@ package org.stellar.sdk; import com.google.common.io.BaseEncoding; -import com.google.common.primitives.Bytes; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.CharArrayWriter; @@ -398,6 +397,9 @@ private static byte[] getMuxedEd25519AccountBytes(MuxedAccount muxedAccount) { int idCopyStartIndex = idBytes.length - idNumBytesToCopy; System.arraycopy( idBytes, idCopyStartIndex, idPaddedBytes, 8 - idNumBytesToCopy, idNumBytesToCopy); - return Bytes.concat(accountBytes, idPaddedBytes); + byte[] result = new byte[accountBytes.length + idPaddedBytes.length]; + System.arraycopy(accountBytes, 0, result, 0, accountBytes.length); + System.arraycopy(idPaddedBytes, 0, result, accountBytes.length, idPaddedBytes.length); + return result; } } diff --git a/src/main/java/org/stellar/sdk/TransactionBuilder.java b/src/main/java/org/stellar/sdk/TransactionBuilder.java index 91e1d165e..b944be13b 100644 --- a/src/main/java/org/stellar/sdk/TransactionBuilder.java +++ b/src/main/java/org/stellar/sdk/TransactionBuilder.java @@ -3,10 +3,10 @@ import static com.google.common.collect.Lists.newArrayList; import static org.stellar.sdk.TransactionPreconditions.TIMEOUT_INFINITE; -import com.google.common.base.Function; import java.math.BigInteger; import java.util.Collection; import java.util.List; +import java.util.function.Function; import lombok.NonNull; import org.stellar.sdk.TransactionPreconditions.TransactionPreconditionsBuilder; import org.stellar.sdk.xdr.SorobanTransactionData; @@ -243,8 +243,8 @@ public Transaction build() { * A default implementation of sequence number generation which will derive a sequence number * based on sourceAccount's current sequence number + 1. */ - public static Function IncrementedSequenceNumberFunc = - sourceAccount -> sourceAccount.getIncrementedSequenceNumber(); + public static Function incrementedSequenceNumberFunc = + TransactionBuilderAccount::getIncrementedSequenceNumber; @Deprecated public static org.stellar.sdk.xdr.TimeBounds buildTimeBounds(long minTime, long maxTime) { diff --git a/src/main/java/org/stellar/sdk/responses/AssetDeserializer.java b/src/main/java/org/stellar/sdk/responses/AssetDeserializer.java index 4b032f03e..9a450f191 100644 --- a/src/main/java/org/stellar/sdk/responses/AssetDeserializer.java +++ b/src/main/java/org/stellar/sdk/responses/AssetDeserializer.java @@ -1,13 +1,11 @@ package org.stellar.sdk.responses; -import static com.google.common.base.Optional.fromNullable; - -import com.google.common.base.Function; import com.google.gson.JsonDeserializationContext; import com.google.gson.JsonDeserializer; import com.google.gson.JsonElement; import com.google.gson.JsonParseException; import java.lang.reflect.Type; +import java.util.Optional; import org.stellar.sdk.Asset; class AssetDeserializer implements JsonDeserializer { @@ -21,23 +19,12 @@ public Asset deserialize(JsonElement json, Type typeOfT, JsonDeserializationCont return Asset.create( json.getAsJsonObject().get("asset_type").getAsString(), - fromNullable(json.getAsJsonObject().get("asset_code")) - .transform(ToString.FUNCTION) - .orNull(), - fromNullable(json.getAsJsonObject().get("asset_issuer")) - .transform(ToString.FUNCTION) - .orNull(), - fromNullable(json.getAsJsonObject().get("liquidity_pool_id")) - .transform(ToString.FUNCTION) - .orNull()); + getValueAsString(json.getAsJsonObject().get("asset_code")), + getValueAsString(json.getAsJsonObject().get("asset_issuer")), + getValueAsString(json.getAsJsonObject().get("liquidity_pool_id"))); } - enum ToString implements Function { - FUNCTION; - - @Override - public String apply(JsonElement input) { - return input.getAsString(); - } + private String getValueAsString(JsonElement element) { + return Optional.ofNullable(element).map(JsonElement::getAsString).orElse(null); } } diff --git a/src/test/java/org/stellar/sdk/MemoTest.java b/src/test/java/org/stellar/sdk/MemoTest.java index 1e5b6ecf9..5669bb953 100644 --- a/src/test/java/org/stellar/sdk/MemoTest.java +++ b/src/test/java/org/stellar/sdk/MemoTest.java @@ -5,7 +5,6 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.base.Strings; import com.google.common.io.BaseEncoding; import com.google.gson.JsonElement; import com.google.gson.JsonParser; @@ -95,7 +94,7 @@ public void testMemoNullHexHashSuccess() { @Test public void testMemoHashSuccess() { - MemoHash memo = Memo.hash(Strings.padEnd("4142434445464748494a4b4c", 64, '0')); + MemoHash memo = Memo.hash("4142434445464748494a4b4c0000000000000000000000000000000000000000"); assertEquals(MemoType.MEMO_HASH, memo.toXdr().getDiscriminant()); String test = "ABCDEFGHIJKL"; assertEquals(test, Util.paddedByteArrayToString(memo.getBytes())); @@ -105,7 +104,8 @@ public void testMemoHashSuccess() { @Test public void testMemoHashSuccessUppercase() { - MemoHash memo = Memo.hash(Strings.padEnd("4142434445464748494a4b4c".toUpperCase(), 64, '0')); + MemoHash memo = + Memo.hash("4142434445464748494a4b4c0000000000000000000000000000000000000000".toUpperCase()); assertEquals(MemoType.MEMO_HASH, memo.toXdr().getDiscriminant()); String test = "ABCDEFGHIJKL"; assertEquals(test, Util.paddedByteArrayToString(memo.getBytes())); From e4b0a2aaf6126888a1537bb8f58a19b83975c552 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Mon, 11 Sep 2023 17:51:22 +0800 Subject: [PATCH 09/20] Remove `com.google.common.primitives.Longs`, add our own implementation. --- .../java/org/stellar/sdk/scval/Longs.java | 36 +++++++++++++++++++ .../java/org/stellar/sdk/scval/ScvInt128.java | 1 - .../java/org/stellar/sdk/scval/ScvInt256.java | 1 - 3 files changed, 36 insertions(+), 2 deletions(-) create mode 100644 src/main/java/org/stellar/sdk/scval/Longs.java diff --git a/src/main/java/org/stellar/sdk/scval/Longs.java b/src/main/java/org/stellar/sdk/scval/Longs.java new file mode 100644 index 000000000..3439e5d07 --- /dev/null +++ b/src/main/java/org/stellar/sdk/scval/Longs.java @@ -0,0 +1,36 @@ +package org.stellar.sdk.scval; + +import lombok.NoArgsConstructor; + +@NoArgsConstructor(access = lombok.AccessLevel.PRIVATE) +final class Longs { + /** + * @return a big-endian representation of {@code value} in an 8-element byte array. + */ + static byte[] toByteArray(long value) { + byte[] result = new byte[8]; + for (int i = 7; i >= 0; i--) { + result[i] = (byte) (value & 0xffL); + value >>= 8; + } + return result; + } + + /** + * @return the {@code long} value whose byte representation is the given 8 bytes, in big-endian + * order. + */ + static long fromByteArray(byte[] bytes) { + if (bytes.length != 8) { + throw new IllegalArgumentException("array length is not 8"); + } + return (bytes[0] & 0xFFL) << 56 + | (bytes[1] & 0xFFL) << 48 + | (bytes[2] & 0xFFL) << 40 + | (bytes[3] & 0xFFL) << 32 + | (bytes[4] & 0xFFL) << 24 + | (bytes[5] & 0xFFL) << 16 + | (bytes[6] & 0xFFL) << 8 + | (bytes[7] & 0xFFL); + } +} diff --git a/src/main/java/org/stellar/sdk/scval/ScvInt128.java b/src/main/java/org/stellar/sdk/scval/ScvInt128.java index 8fed7cec2..2326483e1 100644 --- a/src/main/java/org/stellar/sdk/scval/ScvInt128.java +++ b/src/main/java/org/stellar/sdk/scval/ScvInt128.java @@ -2,7 +2,6 @@ import static org.stellar.sdk.Util.getBytes; -import com.google.common.primitives.Longs; import java.math.BigInteger; import java.util.Arrays; import org.stellar.sdk.xdr.Int128Parts; diff --git a/src/main/java/org/stellar/sdk/scval/ScvInt256.java b/src/main/java/org/stellar/sdk/scval/ScvInt256.java index 8a9540f3f..2eab891b1 100644 --- a/src/main/java/org/stellar/sdk/scval/ScvInt256.java +++ b/src/main/java/org/stellar/sdk/scval/ScvInt256.java @@ -2,7 +2,6 @@ import static org.stellar.sdk.Util.getBytes; -import com.google.common.primitives.Longs; import java.math.BigInteger; import java.util.Arrays; import org.stellar.sdk.xdr.Int256Parts; From 91e3cc168269d5e47bbb11691125ebae6cb0f05d Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Tue, 12 Sep 2023 10:30:26 +0800 Subject: [PATCH 10/20] Use the self-implemented base16 and build-in base64 module instead of guava --- .../org/stellar/sdk/AbstractTransaction.java | 3 +- .../sdk/ClaimClaimableBalanceOperation.java | 5 +- .../ClawbackClaimableBalanceOperation.java | 5 +- .../org/stellar/sdk/MemoHashAbstract.java | 5 +- ...eClaimableBalanceSponsorshipOperation.java | 8 +-- .../java/org/stellar/sdk/Sep10Challenge.java | 8 +-- .../sdk/responses/AccountResponse.java | 5 +- .../responses/SubmitTransactionResponse.java | 5 +- .../responses/TransactionDeserializer.java | 14 ++-- .../java/org/stellar/sdk/AddressTest.java | 20 ++---- src/test/java/org/stellar/sdk/MemoTest.java | 3 +- .../java/org/stellar/sdk/OperationTest.java | 13 +--- .../org/stellar/sdk/Sep10ChallengeTest.java | 72 +++++++------------ .../stellar/sdk/SetOptionsOperationTest.java | 6 +- .../stellar/sdk/SignedPayloadSignerTest.java | 8 +-- src/test/java/org/stellar/sdk/SignerTest.java | 6 +- .../org/stellar/sdk/SorobanServerTest.java | 70 +++++++----------- src/test/java/org/stellar/sdk/StrKeyTest.java | 9 +-- .../stellar/sdk/TransactionBuilderTest.java | 35 +++------ .../sdk/TransactionPreconditionsTest.java | 6 +- .../java/org/stellar/sdk/TransactionTest.java | 9 +-- .../sdk/xdr/AccountEntryDecodeTest.java | 15 +--- .../sdk/xdr/TransactionDecodeTest.java | 33 ++------- 23 files changed, 113 insertions(+), 250 deletions(-) diff --git a/src/main/java/org/stellar/sdk/AbstractTransaction.java b/src/main/java/org/stellar/sdk/AbstractTransaction.java index 79786e15e..b391e3347 100644 --- a/src/main/java/org/stellar/sdk/AbstractTransaction.java +++ b/src/main/java/org/stellar/sdk/AbstractTransaction.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; @@ -64,7 +63,7 @@ public byte[] hash() { /** Returns transaction hash encoded as a hexadecimal string. */ public String hashHex() { - return BaseEncoding.base16().lowerCase().encode(this.hash()); + return Util.bytesToHex(this.hash()).toLowerCase(); } /** Returns signature base. */ diff --git a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java index f59c3ba80..f9f097d86 100644 --- a/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/ClaimClaimableBalanceOperation.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.Objects; import lombok.NonNull; @@ -19,7 +18,7 @@ public String getBalanceId() { @Override org.stellar.sdk.xdr.Operation.OperationBody toOperationBody(AccountConverter accountConverter) { - byte[] balanceIdBytes = BaseEncoding.base16().lowerCase().decode(this.balanceId.toLowerCase()); + byte[] balanceIdBytes = Util.hexToBytes(this.balanceId); ClaimableBalanceID balanceId; try { balanceId = ClaimableBalanceID.fromXdrByteArray(balanceIdBytes); @@ -48,7 +47,7 @@ public static class Builder { */ Builder(ClaimClaimableBalanceOp op) { try { - balanceId = BaseEncoding.base16().lowerCase().encode(op.getBalanceID().toXdrByteArray()); + balanceId = Util.bytesToHex(op.getBalanceID().toXdrByteArray()).toLowerCase(); } catch (IOException e) { throw new IllegalArgumentException("Invalid balanceId in the operation", e); } diff --git a/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java b/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java index f2d7501b2..d5196da6f 100644 --- a/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java +++ b/src/main/java/org/stellar/sdk/ClawbackClaimableBalanceOperation.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.Objects; import lombok.NonNull; @@ -28,7 +27,7 @@ public String getBalanceId() { @Override org.stellar.sdk.xdr.Operation.OperationBody toOperationBody(AccountConverter accountConverter) { - byte[] balanceIdBytes = BaseEncoding.base16().lowerCase().decode(this.balanceId.toLowerCase()); + byte[] balanceIdBytes = Util.hexToBytes(this.balanceId); ClaimableBalanceID balanceId; try { balanceId = ClaimableBalanceID.fromXdrByteArray(balanceIdBytes); @@ -59,7 +58,7 @@ public static class Builder { Builder(ClawbackClaimableBalanceOp op) { try { - balanceId = BaseEncoding.base16().lowerCase().encode(op.getBalanceID().toXdrByteArray()); + balanceId = Util.bytesToHex(op.getBalanceID().toXdrByteArray()).toLowerCase(); } catch (IOException e) { throw new IllegalArgumentException("Invalid balanceId in the operation", e); } diff --git a/src/main/java/org/stellar/sdk/MemoHashAbstract.java b/src/main/java/org/stellar/sdk/MemoHashAbstract.java index 423d1d7b2..d954e6c29 100644 --- a/src/main/java/org/stellar/sdk/MemoHashAbstract.java +++ b/src/main/java/org/stellar/sdk/MemoHashAbstract.java @@ -2,7 +2,6 @@ import static com.google.common.base.Preconditions.checkArgument; -import com.google.common.io.BaseEncoding; import java.util.Arrays; import lombok.NonNull; @@ -16,7 +15,7 @@ public MemoHashAbstract(byte @NonNull [] bytes) { public MemoHashAbstract(String hexString) { // We change to lowercase because we want to decode both: upper cased and lower cased alphabets. - this(BaseEncoding.base16().lowerCase().decode(hexString.toLowerCase())); + this(Util.hexToBytes(hexString.toLowerCase())); } /** Returns 32 bytes long array contained in this memo. */ @@ -33,7 +32,7 @@ public byte[] getBytes() { * */ public String getHexValue() { - return BaseEncoding.base16().lowerCase().encode(this.bytes); + return Util.bytesToHex(this.bytes).toLowerCase(); } @Override diff --git a/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java b/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java index efa4215fb..7c3fb0efc 100644 --- a/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java +++ b/src/main/java/org/stellar/sdk/RevokeClaimableBalanceSponsorshipOperation.java @@ -1,6 +1,5 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.IOException; import java.util.Objects; import lombok.NonNull; @@ -19,7 +18,7 @@ public String getBalanceId() { @Override org.stellar.sdk.xdr.Operation.OperationBody toOperationBody(AccountConverter accountConverter) { - byte[] balanceIdBytes = BaseEncoding.base16().lowerCase().decode(this.balanceId.toLowerCase()); + byte[] balanceIdBytes = Util.hexToBytes(this.balanceId); ClaimableBalanceID balanceId; try { balanceId = ClaimableBalanceID.fromXdrByteArray(balanceIdBytes); @@ -60,9 +59,8 @@ public static class Builder { Builder(RevokeSponsorshipOp op) { try { balanceId = - BaseEncoding.base16() - .lowerCase() - .encode(op.getLedgerKey().getClaimableBalance().getBalanceID().toXdrByteArray()); + Util.bytesToHex(op.getLedgerKey().getClaimableBalance().getBalanceID().toXdrByteArray()) + .toLowerCase(); } catch (IOException e) { throw new IllegalArgumentException("Invalid claimableBalance in the operation", e); } diff --git a/src/main/java/org/stellar/sdk/Sep10Challenge.java b/src/main/java/org/stellar/sdk/Sep10Challenge.java index 36e1f45dc..a47526b75 100644 --- a/src/main/java/org/stellar/sdk/Sep10Challenge.java +++ b/src/main/java/org/stellar/sdk/Sep10Challenge.java @@ -1,11 +1,11 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.IOException; import java.math.BigInteger; import java.security.SecureRandom; import java.util.ArrayList; import java.util.Arrays; +import java.util.Base64; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; @@ -84,8 +84,7 @@ public static Transaction newChallenge( byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); if (clientDomain.isEmpty() != clientSigningKey.isEmpty()) { throw new InvalidSep10ChallengeException( @@ -309,10 +308,9 @@ public static ChallengeTransaction readChallengeTransaction( "Random nonce encoded as base64 should be 64 bytes long."); } - BaseEncoding base64Encoding = BaseEncoding.base64(); byte[] nonce; try { - nonce = base64Encoding.decode(new String(manageDataOperation.getValue())); + nonce = Base64.getDecoder().decode(new String(manageDataOperation.getValue())); } catch (IllegalArgumentException e) { throw new InvalidSep10ChallengeException( "Failed to decode random nonce provided in ManageData operation.", e); diff --git a/src/main/java/org/stellar/sdk/responses/AccountResponse.java b/src/main/java/org/stellar/sdk/responses/AccountResponse.java index 795fddb1a..5d3390a1f 100644 --- a/src/main/java/org/stellar/sdk/responses/AccountResponse.java +++ b/src/main/java/org/stellar/sdk/responses/AccountResponse.java @@ -2,8 +2,8 @@ import static org.stellar.sdk.Asset.create; -import com.google.common.io.BaseEncoding; import com.google.gson.annotations.SerializedName; +import java.util.Base64; import java.util.HashMap; import java.util.Optional; import lombok.NonNull; @@ -440,8 +440,7 @@ public String get(String key) { * @return raw value */ public byte[] getDecoded(String key) { - BaseEncoding base64Encoding = BaseEncoding.base64(); - return base64Encoding.decode(this.get(key)); + return Base64.getDecoder().decode(this.get(key)); } } diff --git a/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java b/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java index b4ad29bbf..9f977f214 100644 --- a/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java +++ b/src/main/java/org/stellar/sdk/responses/SubmitTransactionResponse.java @@ -1,10 +1,10 @@ package org.stellar.sdk.responses; -import com.google.common.io.BaseEncoding; import com.google.gson.annotations.SerializedName; import java.io.ByteArrayInputStream; import java.io.IOException; import java.util.ArrayList; +import java.util.Base64; import java.util.Optional; import org.stellar.sdk.Server; import org.stellar.sdk.xdr.OperationResult; @@ -151,8 +151,7 @@ public Optional getDecodedTransactionResult() throws IOExcept if (!resultXDR.isPresent()) { return Optional.empty(); } - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(resultXDR.get()); + byte[] bytes = Base64.getDecoder().decode(resultXDR.get()); ByteArrayInputStream inputStream = new ByteArrayInputStream(bytes); XdrDataInputStream xdrInputStream = new XdrDataInputStream(inputStream); this.transactionResult = TransactionResult.decode(xdrInputStream); diff --git a/src/main/java/org/stellar/sdk/responses/TransactionDeserializer.java b/src/main/java/org/stellar/sdk/responses/TransactionDeserializer.java index 01ceae628..9faf0d2df 100644 --- a/src/main/java/org/stellar/sdk/responses/TransactionDeserializer.java +++ b/src/main/java/org/stellar/sdk/responses/TransactionDeserializer.java @@ -1,11 +1,11 @@ package org.stellar.sdk.responses; -import com.google.common.io.BaseEncoding; import com.google.gson.*; import java.io.ByteArrayInputStream; import java.io.IOException; import java.lang.reflect.Type; import java.math.BigInteger; +import java.util.Base64; import org.stellar.sdk.Memo; import org.stellar.sdk.xdr.TransactionEnvelope; import org.stellar.sdk.xdr.XdrDataInputStream; @@ -54,19 +54,19 @@ public TransactionResponse deserialize( // representation of a transaction. That's why we need to handle a special case // here. if (memoType.equals("text")) { - BaseEncoding base64Encoding = BaseEncoding.base64(); + Base64.Decoder base64Decoder = Base64.getDecoder(); JsonObject jsonResponse = json.getAsJsonObject(); if (jsonResponse.has("memo_bytes")) { // we obtain the memo text from the "memo_bytes" field because the original byte sequence // may not be valid utf8 String memoBase64 = json.getAsJsonObject().get("memo_bytes").getAsString(); - memo = Memo.text(base64Encoding.decode(memoBase64)); + memo = Memo.text(base64Decoder.decode(memoBase64)); } else { // memo_bytes is not available because horizon is running a version older than 1.2.0 // so we will recover the bytes from the xdr String envelopeXdr = json.getAsJsonObject().get("envelope_xdr").getAsString(); - byte[] bytes = base64Encoding.decode(envelopeXdr); + byte[] bytes = base64Decoder.decode(envelopeXdr); TransactionEnvelope transactionEnvelope = null; try { transactionEnvelope = @@ -80,13 +80,13 @@ public TransactionResponse deserialize( } } else { String memoValue = json.getAsJsonObject().get("memo").getAsString(); - BaseEncoding base64Encoding = BaseEncoding.base64(); + Base64.Decoder base64Decoder = Base64.getDecoder(); if (memoType.equals("id")) { memo = Memo.id(new BigInteger(memoValue)); } else if (memoType.equals("hash")) { - memo = Memo.hash(base64Encoding.decode(memoValue)); + memo = Memo.hash(base64Decoder.decode(memoValue)); } else if (memoType.equals("return")) { - memo = Memo.returnHash(base64Encoding.decode(memoValue)); + memo = Memo.returnHash(base64Decoder.decode(memoValue)); } else { throw new JsonParseException("Unknown memo type."); } diff --git a/src/test/java/org/stellar/sdk/AddressTest.java b/src/test/java/org/stellar/sdk/AddressTest.java index 6a2000d90..e878fafbe 100644 --- a/src/test/java/org/stellar/sdk/AddressTest.java +++ b/src/test/java/org/stellar/sdk/AddressTest.java @@ -3,9 +3,9 @@ import static junit.framework.TestCase.assertEquals; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import java.io.ByteArrayInputStream; import java.io.IOException; +import java.util.Base64; import org.junit.Assert; import org.junit.Test; import org.stellar.sdk.xdr.SCAddress; @@ -76,8 +76,7 @@ public void testToSCAddressAccount() throws IOException { SCAddress scAddress = address.toSCAddress(); String xdr = "AAAAAAAAAAA/DDS/k60NmXHQTMyQ9wVRHIOKrZc0pKL7DXoD/H/omg=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCAddress expectScAddress = SCAddress.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); assertEquals(scAddress, expectScAddress); @@ -90,8 +89,7 @@ public void testToSCAddressContract() throws IOException { SCAddress scAddress = address.toSCAddress(); String xdr = "AAAAAT8MNL+TrQ2ZcdBMzJD3BVEcg4qtlzSkovsNegP8f+ia"; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCAddress expectScAddress = SCAddress.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); assertEquals(scAddress, expectScAddress); @@ -100,8 +98,7 @@ public void testToSCAddressContract() throws IOException { @Test public void testFromSCAddressAccount() throws IOException { String xdr = "AAAAAAAAAAA/DDS/k60NmXHQTMyQ9wVRHIOKrZc0pKL7DXoD/H/omg=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCAddress scAddress = SCAddress.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); Address address = Address.fromSCAddress(scAddress); @@ -113,8 +110,7 @@ public void testFromSCAddressAccount() throws IOException { @Test public void testFromSCAddressContract() throws IOException { String xdr = "AAAAAT8MNL+TrQ2ZcdBMzJD3BVEcg4qtlzSkovsNegP8f+ia"; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCAddress scAddress = SCAddress.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); Address address = Address.fromSCAddress(scAddress); @@ -130,8 +126,7 @@ public void testToSCVal() throws IOException { SCVal scVal = address.toSCVal(); String xdr = "AAAAEgAAAAE/DDS/k60NmXHQTMyQ9wVRHIOKrZc0pKL7DXoD/H/omg=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCVal expectSCVal = SCVal.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); assertEquals(scVal, expectSCVal); } @@ -139,8 +134,7 @@ public void testToSCVal() throws IOException { @Test public void testFromSCVal() throws IOException { String xdr = "AAAAEgAAAAE/DDS/k60NmXHQTMyQ9wVRHIOKrZc0pKL7DXoD/H/omg=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(xdr); + byte[] bytes = Base64.getDecoder().decode(xdr); SCVal scVal = SCVal.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); Address address = Address.fromSCVal(scVal); diff --git a/src/test/java/org/stellar/sdk/MemoTest.java b/src/test/java/org/stellar/sdk/MemoTest.java index 5669bb953..133c5aea6 100644 --- a/src/test/java/org/stellar/sdk/MemoTest.java +++ b/src/test/java/org/stellar/sdk/MemoTest.java @@ -5,7 +5,6 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import com.google.gson.JsonElement; import com.google.gson.JsonParser; import java.math.BigInteger; @@ -163,6 +162,6 @@ public void testMemoReturnHashSuccess() { assertNull(memoXdr.getHash()); assertEquals( "4142434445464748494a4b4c0000000000000000000000000000000000000000", - BaseEncoding.base16().lowerCase().encode(memoXdr.getRetHash().getHash())); + Util.bytesToHex(memoXdr.getRetHash().getHash()).toLowerCase()); } } diff --git a/src/test/java/org/stellar/sdk/OperationTest.java b/src/test/java/org/stellar/sdk/OperationTest.java index 4ec137b01..55a61d1e0 100644 --- a/src/test/java/org/stellar/sdk/OperationTest.java +++ b/src/test/java/org/stellar/sdk/OperationTest.java @@ -6,15 +6,12 @@ import static org.junit.Assert.fail; import static org.stellar.sdk.Asset.create; -import com.google.common.io.BaseEncoding; -import java.io.ByteArrayInputStream; import java.io.IOException; import java.util.Arrays; import java.util.EnumSet; import org.junit.Test; import org.stellar.sdk.xdr.SignerKey; import org.stellar.sdk.xdr.TrustLineFlags; -import org.stellar.sdk.xdr.XdrDataInputStream; public class OperationTest { @@ -750,12 +747,9 @@ public void testManageSellOfferOperation_BadArithmeticRegression() throws IOExce String transactionEnvelopeToDecode = "AAAAAButy5zasS3DLZ5uFpZHL25aiHUfKRwdv1+3Wp12Ce7XAAAAZAEyGwYAAAAOAAAAAAAAAAAAAAABAAAAAQAAAAAbrcuc2rEtwy2ebhaWRy9uWoh1HykcHb9ft1qddgnu1wAAAAMAAAAAAAAAAUtJTgAAAAAARkrT28ebM6YQyhVZi1ttlwq/dk6ijTpyTNuHIMgUp+EAAAAAAAARPSfDKZ0AAv7oAAAAAAAAAAAAAAAAAAAAAXYJ7tcAAABAbE8rEoFt0Hcv41iwVCl74C1Hyr+Lj8ZyaYn7zTJhezClbc+pTW1KgYFIZOJiGVth2xFnBT1pMXuQkVdTlB3FCw=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(transactionEnvelopeToDecode); org.stellar.sdk.xdr.TransactionEnvelope transactionEnvelope = - org.stellar.sdk.xdr.TransactionEnvelope.decode( - new XdrDataInputStream(new ByteArrayInputStream(bytes))); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transactionEnvelopeToDecode); assertEquals(1, transactionEnvelope.getV0().getTx().getOperations().length); ManageSellOfferOperation op = @@ -773,12 +767,9 @@ public void testManageBuyOfferOperation_BadArithmeticRegression() throws IOExcep String transactionEnvelopeToDecode = "AAAAAButy5zasS3DLZ5uFpZHL25aiHUfKRwdv1+3Wp12Ce7XAAAAZAEyGwYAAAAxAAAAAAAAAAAAAAABAAAAAQAAAAAbrcuc2rEtwy2ebhaWRy9uWoh1HykcHb9ft1qddgnu1wAAAAwAAAABS0lOAAAAAABGStPbx5szphDKFVmLW22XCr92TqKNOnJM24cgyBSn4QAAAAAAAAAAACNyOCfDKZ0AAv7oAAAAAAABv1IAAAAAAAAAAA=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(transactionEnvelopeToDecode); org.stellar.sdk.xdr.TransactionEnvelope transactionEnvelope = - org.stellar.sdk.xdr.TransactionEnvelope.decode( - new XdrDataInputStream(new ByteArrayInputStream(bytes))); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transactionEnvelopeToDecode); assertEquals(1, transactionEnvelope.getV0().getTx().getOperations().length); ManageBuyOfferOperation op = diff --git a/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java b/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java index 787d8db74..95ca1e0d9 100644 --- a/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java +++ b/src/test/java/org/stellar/sdk/Sep10ChallengeTest.java @@ -5,10 +5,11 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import java.io.IOException; +import java.nio.charset.StandardCharsets; import java.security.SecureRandom; import java.util.Arrays; +import java.util.Base64; import java.util.Collections; import java.util.HashSet; import java.util.Set; @@ -46,8 +47,7 @@ public void testChallenge() throws InvalidSep10ChallengeException { assertEquals(domainName + " auth", homeDomainOp.getName()); assertEquals(64, homeDomainOp.getValue().length); - BaseEncoding base64Encoding = BaseEncoding.base64(); - assertTrue(base64Encoding.canDecode(new String(homeDomainOp.getValue()))); + Base64.getDecoder().decode(new String(homeDomainOp.getValue())); ManageDataOperation webAuthDomainOp = (ManageDataOperation) transaction.getOperations()[1]; assertEquals(server.getAccountId(), webAuthDomainOp.getSourceAccount()); @@ -287,8 +287,7 @@ public void testReadChallengeTransactionInvalidNotSignedByServer() throws IOExce byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -396,8 +395,7 @@ public void testReadChallengeTransactionInvalidSeqNoNotZero() throws IOException byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), 100L); ManageDataOperation manageDataOperation1 = @@ -442,8 +440,7 @@ public void testReadChallengeTransactionInvalidTimeboundsInfinite() throws IOExc byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation = @@ -613,8 +610,7 @@ public void testReadChallengeTransactionInvalidOperationNoSourceAccount() throws byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -657,8 +653,7 @@ public void testReadChallengeTransactionInvalidDataValueWrongEncodedLength() thr byte[] nonce = new byte[32]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -700,7 +695,8 @@ public void testReadChallengeTransactionInvalidDataValueCorruptBase64() throws I TimeBounds timeBounds = new TimeBounds(now, end); byte[] encodedNonce = - "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA?AAAAAAAAAAAAAAAAAAAAAAAAAA".getBytes("UTF-8"); + "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA?AAAAAAAAAAAAAAAAAAAAAAAAAA" + .getBytes(StandardCharsets.UTF_8); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = new ManageDataOperation.Builder(domainName + " auth", encodedNonce) @@ -725,9 +721,7 @@ public void testReadChallengeTransactionInvalidDataValueCorruptBase64() throws I } catch (InvalidSep10ChallengeException e) { assertEquals( "Failed to decode random nonce provided in ManageData operation.", e.getMessage()); - assertEquals( - "com.google.common.io.BaseEncoding$DecodingException: Unrecognized character: ?", - e.getCause().getMessage()); + assertEquals("Illegal base64 character 3f", e.getCause().getMessage()); } } @@ -747,8 +741,7 @@ public void testReadChallengeTransactionInvalidDataValueWrongByteLength() throws byte[] nonce = new byte[47]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -834,8 +827,7 @@ public void testReadChallengeTransactionInvalidDataValueIsNull() throws IOExcept byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -883,8 +875,7 @@ public void testReadChallengeTransactionInvalidDataValueIsNull() throws IOExcept byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -932,8 +923,7 @@ public void testReadChallengeTransactionInvalidAdditionalManageDataOpsWithSource byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -978,8 +968,7 @@ public void testReadChallengeTransactionInvalidAdditionalOpsOfOtherTypes() throw byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -1230,8 +1219,7 @@ public void testReadChallengeTransactionInvalidWebAuthDomainOperationValueIsNull byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation domainNameOperation = @@ -1280,8 +1268,7 @@ public void testReadChallengeTransactionInvalidWebAuthDomainOperationValueIsNull byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation domainNameOperation = @@ -1352,8 +1339,7 @@ public void testChallengeWithClientDomain() throws InvalidSep10ChallengeExceptio assertEquals(domainName + " auth", homeDomainOp.getName()); assertEquals(64, homeDomainOp.getValue().length); - BaseEncoding base64Encoding = BaseEncoding.base64(); - assertTrue(base64Encoding.canDecode(new String(homeDomainOp.getValue()))); + Base64.getDecoder().decode(new String(homeDomainOp.getValue())); ManageDataOperation webAuthDomainOp = (ManageDataOperation) transaction.getOperations()[1]; assertEquals(server.getAccountId(), webAuthDomainOp.getSourceAccount()); @@ -1444,7 +1430,7 @@ public void testVerifyChallengeWithClientDomain() transaction.sign(clientDomainSigner); // should pass if clientDomainSigner is omitted from signers set - Set signers = new HashSet(Arrays.asList(client.getAccountId())); + Set signers = new HashSet<>(Collections.singletonList(client.getAccountId())); Sep10Challenge.verifyChallengeTransactionSigners( transaction.toEnvelopeXdrBase64(), server.getAccountId(), @@ -1529,8 +1515,7 @@ public void testVerifyChallengeTransactionThresholdInvalidNotSignedByServer() th byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -2079,8 +2064,7 @@ public void testVerifyChallengeTransactionSignersInvalidServer() throws IOExcept byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation manageDataOperation1 = @@ -2676,8 +2660,7 @@ public void testVerifyChallengeTransactionSignersInvalidNoSignersEmptySet() byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -2730,8 +2713,7 @@ public void testVerifyChallengeTransactionSignersInvalidNoSignersEmptySet() byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -2787,8 +2769,7 @@ public void testVerifyChallengeTransactionSignersInvalidNoSignersEmptySet() byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = @@ -2840,8 +2821,7 @@ public void testVerifyChallengeTransactionInvalidAdditionalOpsOfOtherTypes() thr byte[] nonce = new byte[48]; SecureRandom random = new SecureRandom(); random.nextBytes(nonce); - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] encodedNonce = base64Encoding.encode(nonce).getBytes(); + byte[] encodedNonce = Base64.getEncoder().encode(nonce); Account sourceAccount = new Account(server.getAccountId(), -1L); ManageDataOperation operation1 = diff --git a/src/test/java/org/stellar/sdk/SetOptionsOperationTest.java b/src/test/java/org/stellar/sdk/SetOptionsOperationTest.java index ab61c79a5..092e4baa7 100644 --- a/src/test/java/org/stellar/sdk/SetOptionsOperationTest.java +++ b/src/test/java/org/stellar/sdk/SetOptionsOperationTest.java @@ -3,7 +3,6 @@ import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; -import com.google.common.io.BaseEncoding; import org.junit.Test; import org.stellar.sdk.xdr.SignerKey; @@ -17,9 +16,8 @@ public void testPaylodSignerKey() { String payloadSignerStrKey = "GA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJVSGZ"; byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); + Util.hexToBytes( + "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); SignedPayloadSigner signedPayloadSigner = new SignedPayloadSigner(StrKey.decodeStellarAccountId(payloadSignerStrKey), payload); SignerKey signerKey = Signer.signedPayload(signedPayloadSigner); diff --git a/src/test/java/org/stellar/sdk/SignedPayloadSignerTest.java b/src/test/java/org/stellar/sdk/SignedPayloadSignerTest.java index 7b5666b35..787ee9759 100644 --- a/src/test/java/org/stellar/sdk/SignedPayloadSignerTest.java +++ b/src/test/java/org/stellar/sdk/SignedPayloadSignerTest.java @@ -2,7 +2,6 @@ import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import org.junit.Test; import org.stellar.sdk.xdr.AccountID; import org.stellar.sdk.xdr.PublicKey; @@ -22,10 +21,9 @@ public void itFailsWhenAccoutIDIsNull() { public void itFailsWhenPayloadLengthTooBig() { String accountStrKey = "GA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJVSGZ"; byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f200102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f2001" - .toUpperCase()); + Util.hexToBytes( + "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f200102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f2001" + .toUpperCase()); try { new SignedPayloadSigner(StrKey.decodeStellarAccountId(accountStrKey), payload); fail("should not create a payload signer if payload > max length"); diff --git a/src/test/java/org/stellar/sdk/SignerTest.java b/src/test/java/org/stellar/sdk/SignerTest.java index 28e7ec6f0..5a3855982 100644 --- a/src/test/java/org/stellar/sdk/SignerTest.java +++ b/src/test/java/org/stellar/sdk/SignerTest.java @@ -3,7 +3,6 @@ import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; -import com.google.common.io.BaseEncoding; import org.junit.Test; import org.stellar.sdk.xdr.SignerKey; @@ -14,9 +13,8 @@ public void itCreatesSignedPayloadSigner() { String accountStrKey = "GA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJVSGZ"; byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); + Util.hexToBytes( + "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); SignedPayloadSigner signedPayloadSigner = new SignedPayloadSigner(StrKey.decodeStellarAccountId(accountStrKey), payload); SignerKey signerKey = Signer.signedPayload(signedPayloadSigner); diff --git a/src/test/java/org/stellar/sdk/SorobanServerTest.java b/src/test/java/org/stellar/sdk/SorobanServerTest.java index 379aef26e..150c2bfcf 100644 --- a/src/test/java/org/stellar/sdk/SorobanServerTest.java +++ b/src/test/java/org/stellar/sdk/SorobanServerTest.java @@ -1,17 +1,14 @@ package org.stellar.sdk; -import static com.google.common.collect.ImmutableList.of; +import static java.util.Collections.singletonList; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; import static org.stellar.sdk.xdr.SCValType.SCV_LEDGER_KEY_CONTRACT_INSTANCE; -import com.google.common.io.BaseEncoding; import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; -import java.io.ByteArrayInputStream; -import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; @@ -67,8 +64,6 @@ import org.stellar.sdk.xdr.SorobanTransactionData; import org.stellar.sdk.xdr.Uint256; import org.stellar.sdk.xdr.Uint32; -import org.stellar.sdk.xdr.XdrDataInputStream; -import org.stellar.sdk.xdr.XdrDataOutputStream; import org.stellar.sdk.xdr.XdrString; import org.stellar.sdk.xdr.XdrUnsignedInteger; @@ -104,7 +99,7 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) throws InterruptedException { GetLedgerEntriesRequest expectedRequest = new GetLedgerEntriesRequest( - of("AAAAAAAAAADBPp7TMinJylnn+6dQXJACNc15LF+aJ2Py1BaR4P10JA==")); + singletonList("AAAAAAAAAADBPp7TMinJylnn+6dQXJACNc15LF+aJ2Py1BaR4P10JA==")); SorobanRpcRequest sorobanRpcRequest = gson.fromJson( recordedRequest.getBody().readUtf8(), @@ -254,8 +249,12 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) .contractData(ledgerKeyContractData) .build(); - GetLedgerEntriesRequest expectedRequest = - new GetLedgerEntriesRequest(of(ledgerKeyToXdrBase64(ledgerKey))); + GetLedgerEntriesRequest expectedRequest = null; + try { + expectedRequest = new GetLedgerEntriesRequest(singletonList(ledgerKey.toXdrBase64())); + } catch (IOException e) { + throw new RuntimeException(e); + } SorobanRpcRequest sorobanRpcRequest = gson.fromJson( recordedRequest.getBody().readUtf8(), @@ -323,8 +322,12 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) .contractData(ledgerKeyContractData) .build(); - GetLedgerEntriesRequest expectedRequest = - new GetLedgerEntriesRequest(of(ledgerKeyToXdrBase64(ledgerKey))); + GetLedgerEntriesRequest expectedRequest = null; + try { + expectedRequest = new GetLedgerEntriesRequest(singletonList(ledgerKey.toXdrBase64())); + } catch (IOException e) { + throw new RuntimeException(e); + } SorobanRpcRequest sorobanRpcRequest = gson.fromJson( recordedRequest.getBody().readUtf8(), @@ -382,7 +385,7 @@ public void testGetLedgerEntries() throws IOException, SorobanRpcErrorResponse { .account(ledgerKeyAccount0) .discriminant(LedgerEntryType.ACCOUNT) .build(); - String ledgerKey0Xdr = ledgerKeyToXdrBase64(ledgerKey0); + String ledgerKey0Xdr = ledgerKey0.toXdrBase64(); String accountId1 = "GDAT5HWTGIU4TSSZ4752OUC4SABDLTLZFRPZUJ3D6LKBNEPA7V2CIG54"; LedgerKey.LedgerKeyAccount ledgerKeyAccount1 = @@ -394,7 +397,7 @@ public void testGetLedgerEntries() throws IOException, SorobanRpcErrorResponse { .account(ledgerKeyAccount1) .discriminant(LedgerEntryType.ACCOUNT) .build(); - String ledgerKey1Xdr = ledgerKeyToXdrBase64(ledgerKey1); + String ledgerKey1Xdr = ledgerKey1.toXdrBase64(); MockWebServer mockWebServer = new MockWebServer(); Dispatcher dispatcher = @@ -543,7 +546,8 @@ public void testGetEvents() throws IOException, SorobanRpcErrorResponse { GetEventsRequest.EventFilter eventFilter = GetEventsRequest.EventFilter.builder() - .contractIds(of("607682f2477a6be8cdf0fdf32be13d5f25a686cc094fd93d5aa3d7b68232d0c0")) + .contractIds( + singletonList("607682f2477a6be8cdf0fdf32be13d5f25a686cc094fd93d5aa3d7b68232d0c0")) .type(EventFilterType.CONTRACT) .topic(Arrays.asList("AAAADwAAAAdDT1VOVEVSAA==", "AAAADwAAAAlpbmNyZW1lbnQAAAA=")) .build(); @@ -846,8 +850,8 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) ((InvokeHostFunctionOperation) transaction.getOperations()[0]).getHostFunction()) .sourceAccount(transaction.getOperations()[0].getSourceAccount()) .auth( - of( - sorobanAuthorizationEntryFromXdrBase64( + singletonList( + SorobanAuthorizationEntry.fromXdrBase64( "AAAAAAAAAAAAAAABxYsr+8TwVOcyT2vyDK0+Am5Bu60abSDD19SRje0WVBEAAAAJaW5jcmVtZW50AAAAAAAAAgAAABIAAAAAAAAAAFi3xKLI8peqjz0kcSgf38zsr+SOVmMxPsGOEqc+ypihAAAAAwAAAAoAAAAA"))) .build(); Transaction expectedTx = @@ -965,8 +969,8 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) ((InvokeHostFunctionOperation) transaction.getOperations()[0]).getHostFunction()) .sourceAccount(transaction.getOperations()[0].getSourceAccount()) .auth( - of( - sorobanAuthorizationEntryFromXdrBase64( + singletonList( + SorobanAuthorizationEntry.fromXdrBase64( "AAAAAAAAAAAAAAABxYsr+8TwVOcyT2vyDK0+Am5Bu60abSDD19SRje0WVBEAAAAJaW5jcmVtZW50AAAAAAAAAgAAABIAAAAAAAAAAFi3xKLI8peqjz0kcSgf38zsr+SOVmMxPsGOEqc+ypihAAAAAwAAAAoAAAAA"))) .build(); Transaction expectedTx = @@ -1054,7 +1058,7 @@ public void testPrepareTransactionWithAuth() .build()) .build(); - Transaction transaction = buildSorobanTransaction(null, of(auth)); + Transaction transaction = buildSorobanTransaction(null, singletonList(auth)); MockWebServer mockWebServer = new MockWebServer(); Dispatcher dispatcher = @@ -1093,7 +1097,7 @@ public MockResponse dispatch(@NotNull RecordedRequest recordedRequest) .hostFunction( ((InvokeHostFunctionOperation) transaction.getOperations()[0]).getHostFunction()) .sourceAccount(transaction.getOperations()[0].getSourceAccount()) - .auth(of(auth)) + .auth(singletonList(auth)) .build(); Transaction expectedTx = new Transaction( @@ -1388,30 +1392,4 @@ private Transaction buildSorobanTransaction( return transactionBuilder.build(); } - - private static SorobanAuthorizationEntry sorobanAuthorizationEntryFromXdrBase64( - String sorobanAuthorizationEntry) { - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(sorobanAuthorizationEntry); - ByteArrayInputStream inputStream = new ByteArrayInputStream(bytes); - XdrDataInputStream xdrInputStream = new XdrDataInputStream(inputStream); - try { - return SorobanAuthorizationEntry.decode(xdrInputStream); - } catch (IOException e) { - throw new IllegalArgumentException( - "invalid ledgerEntryData: " + sorobanAuthorizationEntry, e); - } - } - - private static String ledgerKeyToXdrBase64(LedgerKey ledgerKey) { - ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); - XdrDataOutputStream xdrDataOutputStream = new XdrDataOutputStream(byteArrayOutputStream); - try { - ledgerKey.encode(xdrDataOutputStream); - } catch (IOException e) { - throw new IllegalArgumentException("invalid ledgerKey.", e); - } - BaseEncoding base64Encoding = BaseEncoding.base64(); - return base64Encoding.encode(byteArrayOutputStream.toByteArray()); - } } diff --git a/src/test/java/org/stellar/sdk/StrKeyTest.java b/src/test/java/org/stellar/sdk/StrKeyTest.java index d82b8cf1a..13df13c81 100644 --- a/src/test/java/org/stellar/sdk/StrKeyTest.java +++ b/src/test/java/org/stellar/sdk/StrKeyTest.java @@ -4,7 +4,6 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import java.io.IOException; import org.junit.Test; import org.stellar.sdk.xdr.AccountID; @@ -141,9 +140,8 @@ public void testRoundTripHashXFromBytes() { public void testValidSignedPayloadEncode() { // Valid signed payload with an ed25519 public key and a 32-byte payload. byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); + Util.hexToBytes( + "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); SignedPayloadSigner signedPayloadSigner = new SignedPayloadSigner( StrKey.decodeStellarAccountId( @@ -156,8 +154,7 @@ public void testValidSignedPayloadEncode() { // Valid signed payload with an ed25519 public key and a 29-byte payload. payload = - BaseEncoding.base16() - .decode("0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d".toUpperCase()); + Util.hexToBytes("0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d".toUpperCase()); signedPayloadSigner = new SignedPayloadSigner( StrKey.decodeStellarAccountId( diff --git a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java index aa6228d9a..4f8ee45e5 100644 --- a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java +++ b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java @@ -3,10 +3,10 @@ import static com.google.common.collect.Lists.newArrayList; import static org.junit.Assert.*; -import com.google.common.io.BaseEncoding; import java.io.ByteArrayInputStream; import java.io.IOException; import java.math.BigInteger; +import org.apache.commons.codec.DecoderException; import org.junit.Test; import org.stellar.sdk.xdr.*; @@ -503,7 +503,7 @@ public void testBuilderSetsMinSeqLedgerGap() throws IOException { } @Test - public void testBuilderExtraSigners() throws IOException { + public void testBuilderExtraSigners() throws IOException, DecoderException { KeyPair source = KeyPair.fromSecretSeed("SCH27VUZZ6UAKB67BDNF6FA42YMBMQCBKXWGMFD5TZ6S5ZZCZFLRXKHS"); KeyPair newAccount = @@ -511,10 +511,9 @@ public void testBuilderExtraSigners() throws IOException { Account account = new Account(source.getAccountId(), 2908908335136768L); String accountStrKey = "GA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJVSGZ"; - byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); + + String encodedString = "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20"; + byte[] payload = Util.hexToBytes(encodedString); SignerKey signerKey = new SignerKey.Builder() @@ -715,12 +714,8 @@ public void testBuilderInfinteTimeoutOnly() throws IOException { // Convert transaction to binary XDR and back again to make sure timeout is correctly // de/serialized. - XdrDataInputStream is = - new XdrDataInputStream( - new ByteArrayInputStream( - BaseEncoding.base64().decode(transaction.toEnvelopeXdrBase64()))); org.stellar.sdk.xdr.TransactionEnvelope decodedTransaction = - org.stellar.sdk.xdr.TransactionEnvelope.decode(is); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transaction.toEnvelopeXdrBase64()); assertEquals( decodedTransaction @@ -769,12 +764,8 @@ public void testBuilderTimeoutOnly() throws IOException { // Convert transaction to binary XDR and back again to make sure timeout is correctly // de/serialized. - XdrDataInputStream is = - new XdrDataInputStream( - new ByteArrayInputStream( - BaseEncoding.base64().decode(transaction.toEnvelopeXdrBase64()))); org.stellar.sdk.xdr.TransactionEnvelope decodedTransaction = - org.stellar.sdk.xdr.TransactionEnvelope.decode(is); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transaction.toEnvelopeXdrBase64()); assertEquals( decodedTransaction @@ -825,12 +816,8 @@ public void testBuilderTimeoutAndMaxTimeNotSet() throws IOException { // Convert transaction to binary XDR and back again to make sure timeout is correctly // de/serialized. - XdrDataInputStream is = - new XdrDataInputStream( - new ByteArrayInputStream( - BaseEncoding.base64().decode(transaction.toEnvelopeXdrBase64()))); org.stellar.sdk.xdr.TransactionEnvelope decodedTransaction = - org.stellar.sdk.xdr.TransactionEnvelope.decode(is); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transaction.toEnvelopeXdrBase64()); assertEquals( decodedTransaction @@ -882,12 +869,8 @@ public void testBuilderInfinteTimeoutAndMaxTimeNotSet() throws FormatException, // Convert transaction to binary XDR and back again to make sure timebounds are correctly // de/serialized. - XdrDataInputStream is = - new XdrDataInputStream( - new ByteArrayInputStream( - BaseEncoding.base64().decode(transaction.toEnvelopeXdrBase64()))); org.stellar.sdk.xdr.TransactionEnvelope decodedTransaction = - org.stellar.sdk.xdr.TransactionEnvelope.decode(is); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transaction.toEnvelopeXdrBase64()); assertEquals( decodedTransaction diff --git a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java index 81940e1dc..5f5364fd9 100644 --- a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java +++ b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java @@ -6,7 +6,6 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; @@ -104,9 +103,8 @@ public void itRoundTripsFromV2ToV1IfOnlyTimeboundsPresent() throws IOException { public void itConvertsToV2Xdr() throws IOException { byte[] payload = - BaseEncoding.base16() - .decode( - "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); + Util.hexToBytes( + "0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20".toUpperCase()); SignerKey signerKey = new SignerKey.Builder() .discriminant(SignerKeyType.SIGNER_KEY_TYPE_ED25519_SIGNED_PAYLOAD) diff --git a/src/test/java/org/stellar/sdk/TransactionTest.java b/src/test/java/org/stellar/sdk/TransactionTest.java index 2724d565b..9ccc4154d 100644 --- a/src/test/java/org/stellar/sdk/TransactionTest.java +++ b/src/test/java/org/stellar/sdk/TransactionTest.java @@ -6,8 +6,6 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.google.common.io.BaseEncoding; -import java.io.ByteArrayInputStream; import java.io.IOException; import java.math.BigInteger; import java.security.SecureRandom; @@ -39,7 +37,6 @@ import org.stellar.sdk.xdr.SorobanTransactionData; import org.stellar.sdk.xdr.Uint256; import org.stellar.sdk.xdr.Uint32; -import org.stellar.sdk.xdr.XdrDataInputStream; import org.stellar.sdk.xdr.XdrUnsignedInteger; public class TransactionTest { @@ -73,12 +70,8 @@ public void testParseV0Transaction() throws FormatException, IOException { transaction.setEnvelopeType(EnvelopeType.ENVELOPE_TYPE_TX_V0); transaction.sign(source); - XdrDataInputStream is = - new XdrDataInputStream( - new ByteArrayInputStream( - BaseEncoding.base64().decode(transaction.toEnvelopeXdrBase64()))); org.stellar.sdk.xdr.TransactionEnvelope decodedTransaction = - org.stellar.sdk.xdr.TransactionEnvelope.decode(is); + org.stellar.sdk.xdr.TransactionEnvelope.fromXdrBase64(transaction.toEnvelopeXdrBase64()); assertEquals(EnvelopeType.ENVELOPE_TYPE_TX_V0, decodedTransaction.getDiscriminant()); Transaction parsed = diff --git a/src/test/java/org/stellar/sdk/xdr/AccountEntryDecodeTest.java b/src/test/java/org/stellar/sdk/xdr/AccountEntryDecodeTest.java index f4004aef8..060cb74e7 100644 --- a/src/test/java/org/stellar/sdk/xdr/AccountEntryDecodeTest.java +++ b/src/test/java/org/stellar/sdk/xdr/AccountEntryDecodeTest.java @@ -3,16 +3,11 @@ import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; -import com.google.common.io.BaseEncoding; -import java.io.ByteArrayInputStream; -import java.io.ByteArrayOutputStream; import java.io.IOException; import org.junit.Test; public class AccountEntryDecodeTest { - BaseEncoding base64Encoding = BaseEncoding.base64(); - @Test public void testDecodeSignerPayload() throws IOException { AccountEntry.Builder bldr = new AccountEntry.Builder(); @@ -80,15 +75,7 @@ public void testDecodeSignerPayload() throws IOException { AccountEntry xdr = bldr.build(); - ByteArrayOutputStream baos = new ByteArrayOutputStream(); - XdrDataOutputStream outputStream = new XdrDataOutputStream(baos); - AccountEntry.encode(outputStream, xdr); - String encodedXdr = base64Encoding.encode(baos.toByteArray()); - - byte[] decodedbBytes = base64Encoding.decode(encodedXdr); - - AccountEntry accountEntry = - AccountEntry.decode(new XdrDataInputStream(new ByteArrayInputStream(decodedbBytes))); + AccountEntry accountEntry = AccountEntry.fromXdrBase64(xdr.toXdrBase64()); assertArrayEquals( new byte[32], accountEntry.getSigners()[0].getKey().getEd25519SignedPayload().getEd25519().getUint256()); diff --git a/src/test/java/org/stellar/sdk/xdr/TransactionDecodeTest.java b/src/test/java/org/stellar/sdk/xdr/TransactionDecodeTest.java index d4153e451..9951c2704 100644 --- a/src/test/java/org/stellar/sdk/xdr/TransactionDecodeTest.java +++ b/src/test/java/org/stellar/sdk/xdr/TransactionDecodeTest.java @@ -3,9 +3,6 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; -import com.google.common.io.BaseEncoding; -import java.io.ByteArrayInputStream; -import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.Arrays; import org.junit.Test; @@ -19,11 +16,8 @@ public void testDecodeTxBody() throws IOException { String txBody = "AAAAAERmsKL73CyLV/HvjyQCERDXXpWE70Xhyb6MR5qPO3yQAAAAZAAIbkEAACD7AAAAAAAAAAN43bSwpXw8tSAhl7TBtQeOZTQAXwAAAAAAAAAAAAAAAAAAAAEAAAABAAAAAP1qe44j+i4uIT+arbD4QDQBt8ryEeJd7a0jskQ3nwDeAAAAAAAAAADdVhDVFrUiS/jPrRpblXY4bAW9u4hbRI2Hhw+2ATsFpQAAAAAtPWvAAAAAAAAAAAGPO3yQAAAAQHGWVHCBsjTyap/OY9JjPHmzWtN2Y2sL98aMERc/xJ3hcWz6kdQAwjlEhilItCyokDHCrvALZy3v/1TlaDqprA0="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(txBody); - TransactionEnvelope transactionEnvelope = - TransactionEnvelope.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); + TransactionEnvelope transactionEnvelope = TransactionEnvelope.fromXdrBase64(txBody); assertEquals( new Long(2373025265623291L), transactionEnvelope.getV0().getTx().getSeqNum().getSequenceNumber().getInt64()); @@ -36,11 +30,7 @@ public void testDecodeTxResult() throws IOException { String txResult = "1exmRdhs3K6CEsvmD+rvuNaxqLfRGu6lkGCLCGOs5N4AAAAAAAAAZAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAA=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(txResult); - - TransactionResultPair transactionResult = - TransactionResultPair.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); + TransactionResultPair transactionResult = TransactionResultPair.fromXdrBase64(txResult); assertEquals( TransactionResultCode.txSUCCESS, transactionResult.getResult().getResult().getDiscriminant()); @@ -53,11 +43,8 @@ public void testDecodeTxMeta() throws IOException { String txMeta = "AAAAAAAAAAEAAAADAAAAAABZMEIAAAAAAAAAAN1WENUWtSJL+M+tGluVdjhsBb27iFtEjYeHD7YBOwWlAAAAAC09a8AAWTBCAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAwBZL8QAAAAAAAAAAP1qe44j+i4uIT+arbD4QDQBt8ryEeJd7a0jskQ3nwDeAALU1gZ4V7UACD1BAAAAHgAAAAoAAAAAAAAAAAAAAAABAAAAAAAACgAAAAARC07BokpLTOF+/vVKBwiAlop7hHGJTNeGGlY4MoPykwAAAAEAAAAAK+Lzfd3yDD+Ov0GbYu1g7SaIBrKZeBUxoCunkLuI7aoAAAABAAAAAERmsKL73CyLV/HvjyQCERDXXpWE70Xhyb6MR5qPO3yQAAAAAQAAAABSORGwAdyuanN3sNOHqNSpACyYdkUM3L8VafUu69EvEgAAAAEAAAAAeCzqJNkMM/jLvyuMIfyFHljBlLCtDyj17RMycPuNtRMAAAABAAAAAIEi4R7juq15ymL00DNlAddunyFT4FyUD4muC4t3bobdAAAAAQAAAACaNpLL5YMfjOTdXVEqrAh99LM12sN6He6pHgCRAa1f1QAAAAEAAAAAqB+lfAPV9ak+Zkv4aTNZwGaFFAfui4+yhM3dGhoYJ+sAAAABAAAAAMNJrEvdMg6M+M+n4BDIdzsVSj/ZI9SvAp7mOOsvAD/WAAAAAQAAAADbHA6xiKB1+G79mVqpsHMOleOqKa5mxDpP5KEp/Xdz9wAAAAEAAAAAAAAAAAAAAAEAWTBCAAAAAAAAAAD9anuOI/ouLiE/mq2w+EA0AbfK8hHiXe2tI7JEN58A3gAC1NXZOuv1AAg9QQAAAB4AAAAKAAAAAAAAAAAAAAAAAQAAAAAAAAoAAAAAEQtOwaJKS0zhfv71SgcIgJaKe4RxiUzXhhpWODKD8pMAAAABAAAAACvi833d8gw/jr9Bm2LtYO0miAaymXgVMaArp5C7iO2qAAAAAQAAAABEZrCi+9wsi1fx748kAhEQ116VhO9F4cm+jEeajzt8kAAAAAEAAAAAUjkRsAHcrmpzd7DTh6jUqQAsmHZFDNy/FWn1LuvRLxIAAAABAAAAAHgs6iTZDDP4y78rjCH8hR5YwZSwrQ8o9e0TMnD7jbUTAAAAAQAAAACBIuEe47qtecpi9NAzZQHXbp8hU+BclA+JrguLd26G3QAAAAEAAAAAmjaSy+WDH4zk3V1RKqwIffSzNdrDeh3uqR4AkQGtX9UAAAABAAAAAKgfpXwD1fWpPmZL+GkzWcBmhRQH7ouPsoTN3RoaGCfrAAAAAQAAAADDSaxL3TIOjPjPp+AQyHc7FUo/2SPUrwKe5jjrLwA/1gAAAAEAAAAA2xwOsYigdfhu/ZlaqbBzDpXjqimuZsQ6T+ShKf13c/cAAAABAAAAAAAAAAA="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(txMeta); - TransactionMeta transactionMeta = - TransactionMeta.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); + TransactionMeta transactionMeta = TransactionMeta.fromXdrBase64(txMeta); assertEquals(1, transactionMeta.getOperations().length); } @@ -65,11 +52,9 @@ public void testDecodeTxMeta() throws IOException { public void testTransactionEnvelopeWithMemo() throws IOException { String transactionEnvelopeToDecode = "AAAAACq1Ixcw1fchtF5aLTSw1zaYAYjb3WbBRd4jqYJKThB9AAAAZAA8tDoAAAALAAAAAAAAAAEAAAAZR29sZCBwYXltZW50IGZvciBzZXJ2aWNlcwAAAAAAAAEAAAAAAAAAAQAAAAARREGslec48mbJJygIwZoLvRtL6/gGL4ss2TOpnOUOhgAAAAFHT0xEAAAAACq1Ixcw1fchtF5aLTSw1zaYAYjb3WbBRd4jqYJKThB9AAAAADuaygAAAAAAAAAAAA=="; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(transactionEnvelopeToDecode); TransactionEnvelope transactionEnvelope = - TransactionEnvelope.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); + TransactionEnvelope.fromXdrBase64(transactionEnvelopeToDecode); assertEquals(1, transactionEnvelope.getV0().getTx().getOperations().length); assertTrue( Arrays.equals( @@ -90,15 +75,9 @@ public void testTransactionEnvelopeWithMemo() throws IOException { public void testRoundtrip() throws IOException { String txBody = "AAAAAM6jLgjKjuXxWkir4M7v0NqoOfODXcFnn6AGlP+d4RxAAAAAZAAIiE4AAAABAAAAAAAAAAEAAAAcyKMl+WDSzuttWkF2DvzKAkkEqeSZ4cZihjGJEAAAAAEAAAAAAAAAAQAAAAAgECmBaDwiRPE1z2vAE36J+45toU/ZxdvpR38tc0HvmgAAAAAAAAAAAJiWgAAAAAAAAAABneEcQAAAAECeXDKebJoAbST1T2AbDBui9K0TbSM8sfbhXUAZ2ROAoCRs5cG1pRvY+ityyPWFEKPd7+3qEupavkAZ/+L7/28G"; - BaseEncoding base64Encoding = BaseEncoding.base64(); - byte[] bytes = base64Encoding.decode(txBody); - - TransactionEnvelope transactionEnvelope = - TransactionEnvelope.decode(new XdrDataInputStream(new ByteArrayInputStream(bytes))); - ByteArrayOutputStream byteOutputStream = new ByteArrayOutputStream(); - transactionEnvelope.encode(new XdrDataOutputStream(byteOutputStream)); - String serialized = base64Encoding.encode(byteOutputStream.toByteArray()); + TransactionEnvelope transactionEnvelope = TransactionEnvelope.fromXdrBase64(txBody); + String serialized = transactionEnvelope.toXdrBase64(); assertEquals(serialized, txBody); } } From e74fd1d0eee6f9a28fc9631b252ae1ec3f5e0054 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Tue, 12 Sep 2023 16:27:42 +0800 Subject: [PATCH 11/20] Introduce commons-codec and use its Base32 module. --- build.gradle | 1 + src/main/java/org/stellar/sdk/StrKey.java | 58 +++++++++++++++-------- 2 files changed, 40 insertions(+), 19 deletions(-) diff --git a/build.gradle b/build.gradle index 5030d5f40..8b8c34a4d 100644 --- a/build.gradle +++ b/build.gradle @@ -76,6 +76,7 @@ dependencies { implementation 'com.google.guava:guava:32.1.2-android' implementation 'com.google.code.gson:gson:2.10.1' implementation 'net.i2p.crypto:eddsa:0.3.0' + implementation 'commons-codec:commons-codec:1.16.0' testImplementation 'org.mockito:mockito-core:5.5.0' testImplementation "com.squareup.okhttp3:mockwebserver:${okhttpclientVersion}" diff --git a/src/main/java/org/stellar/sdk/StrKey.java b/src/main/java/org/stellar/sdk/StrKey.java index b8d71e6ff..d00702c52 100644 --- a/src/main/java/org/stellar/sdk/StrKey.java +++ b/src/main/java/org/stellar/sdk/StrKey.java @@ -1,13 +1,12 @@ package org.stellar.sdk; -import com.google.common.io.BaseEncoding; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import java.io.CharArrayWriter; import java.io.IOException; -import java.io.OutputStream; import java.util.Arrays; import java.util.Optional; +import org.apache.commons.codec.binary.Base32; +import org.apache.commons.codec.binary.Base32OutputStream; import org.stellar.sdk.xdr.AccountID; import org.stellar.sdk.xdr.CryptoKeyType; import org.stellar.sdk.xdr.MuxedAccount; @@ -24,8 +23,7 @@ class StrKey { public static final int ACCOUNT_ID_ADDRESS_LENGTH = 56; private static final byte[] b32Table = decodingTable(); - private static final BaseEncoding base32Encoding = - BaseEncoding.base32().upperCase().omitPadding(); + private static final Base32 base32Codec = new Base32(); public static String encodeContractId(byte[] data) { char[] encoded = encodeCheck(VersionByte.CONTRACT, data); @@ -141,7 +139,7 @@ public static MuxedAccount encodeToXDRMuxedAccount(String data) { } public static VersionByte decodeVersionByte(String data) { - byte[] decoded = StrKey.base32Encoding.decode(java.nio.CharBuffer.wrap(data.toCharArray())); + byte[] decoded = base32Codec.decode(data); byte decodedVersionByte = decoded[0]; Optional versionByteOptional = VersionByte.findByValue(decodedVersionByte); if (!versionByteOptional.isPresent()) { @@ -239,28 +237,31 @@ protected static char[] encodeCheck(VersionByte versionByte, byte[] data) { byte[] unencoded = outputStream.toByteArray(); if (VersionByte.SEED != versionByte) { - return base32Encoding.encode(unencoded).toCharArray(); + return bytesToChars(removeBase32Padding(base32Codec.encode(unencoded))); } - // Why not use base32Encoding.encode here? + // Why not use base32Codec.encode here? // We don't want secret seed to be stored as String in memory because of security reasons. // It's impossible // to erase it from memory when we want it to be erased (ASAP). - CharArrayWriter charArrayWriter = new CharArrayWriter(unencoded.length); - OutputStream charOutputStream = base32Encoding.encodingStream(charArrayWriter); - charOutputStream.write(unencoded); - char[] charsEncoded = charArrayWriter.toCharArray(); + ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(unencoded.length); + Base32OutputStream base32OutputStream = new Base32OutputStream(byteArrayOutputStream); + base32OutputStream.write(unencoded); + base32OutputStream.close(); + byte[] encodedBytes = byteArrayOutputStream.toByteArray(); + char[] charsEncoded = bytesToChars(encodedBytes); + + Arrays.fill(encodedBytes, (byte) 0); Arrays.fill(unencoded, (byte) 0); Arrays.fill(payload, (byte) 0); Arrays.fill(checksum, (byte) 0); - // Clean charArrayWriter internal buffer - int bufferSize = charArrayWriter.size(); - char[] zeros = new char[bufferSize]; - Arrays.fill(zeros, '0'); - charArrayWriter.reset(); - charArrayWriter.write(zeros); + // Clean byteArrayOutputStream internal buffer + int size = byteArrayOutputStream.size(); + byteArrayOutputStream.reset(); + byteArrayOutputStream.write(new byte[size]); + byteArrayOutputStream.close(); return charsEncoded; } catch (IOException e) { @@ -297,7 +298,7 @@ protected static byte[] decodeCheck(VersionByte versionByte, char[] encoded) { } } - byte[] decoded = base32Encoding.decode(java.nio.CharBuffer.wrap(encoded)); + byte[] decoded = base32Codec.decode(bytes); byte decodedVersionByte = decoded[0]; byte[] payload = Arrays.copyOfRange(decoded, 0, decoded.length - 2); byte[] data = Arrays.copyOfRange(payload, 1, payload.length); @@ -402,4 +403,23 @@ private static byte[] getMuxedEd25519AccountBytes(MuxedAccount muxedAccount) { System.arraycopy(idPaddedBytes, 0, result, accountBytes.length, idPaddedBytes.length); return result; } + + private static byte[] removeBase32Padding(byte[] data) { + // Calculate the length of unpadded data + int unpaddedLength = data.length; + while (unpaddedLength > 0 && data[unpaddedLength - 1] == '=') { + unpaddedLength--; + } + + // Create a copy of the data without padding bytes + return Arrays.copyOf(data, unpaddedLength); + } + + private static char[] bytesToChars(byte[] data) { + char[] chars = new char[data.length]; + for (int i = 0; i < data.length; i++) { + chars[i] = (char) (data[i] & 0xFF); + } + return chars; + } } From cef858d8565706ee5936dfeec804ec8ebc1dae3d Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Tue, 12 Sep 2023 17:48:17 +0800 Subject: [PATCH 12/20] fixup! Use `java.util.Objects` instead of `com.google.common.base.Objects` --- .../operations/LiquidityPoolWithdrawOperationResponse.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/org/stellar/sdk/responses/operations/LiquidityPoolWithdrawOperationResponse.java b/src/main/java/org/stellar/sdk/responses/operations/LiquidityPoolWithdrawOperationResponse.java index d564e046a..a140d0a8b 100644 --- a/src/main/java/org/stellar/sdk/responses/operations/LiquidityPoolWithdrawOperationResponse.java +++ b/src/main/java/org/stellar/sdk/responses/operations/LiquidityPoolWithdrawOperationResponse.java @@ -59,8 +59,8 @@ public boolean equals(Object object) { LiquidityPoolWithdrawOperationResponse o = (LiquidityPoolWithdrawOperationResponse) object; return Objects.equals(this.getLiquidityPoolId(), o.getLiquidityPoolId()) - && Objects.equals(this.getReservesMin(), o.getReservesMin()) - && Objects.equals(this.getReservesReceived(), o.getReservesReceived()) + && Arrays.equals(this.getReservesMin(), o.getReservesMin()) + && Arrays.equals(this.getReservesReceived(), o.getReservesReceived()) && Objects.equals(this.getShares(), o.getShares()); } } From e9a32699e8b5e8f6fb5c5930d3472c5e3cd942c7 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Tue, 12 Sep 2023 17:52:17 +0800 Subject: [PATCH 13/20] fixup! Introduce commons-codec and use its Base32 module. --- src/main/java/org/stellar/sdk/StrKey.java | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/stellar/sdk/StrKey.java b/src/main/java/org/stellar/sdk/StrKey.java index d00702c52..7856fef90 100644 --- a/src/main/java/org/stellar/sdk/StrKey.java +++ b/src/main/java/org/stellar/sdk/StrKey.java @@ -106,7 +106,7 @@ public static AccountID encodeToXDRAccountId(String data) { public static MuxedAccount encodeToXDRMuxedAccount(String data) { MuxedAccount muxed = new MuxedAccount(); - if (data.length() == 0) { + if (data.isEmpty()) { throw new IllegalArgumentException("address is empty"); } switch (decodeVersionByte(data)) { @@ -250,12 +250,14 @@ protected static char[] encodeCheck(VersionByte versionByte, byte[] data) { base32OutputStream.close(); byte[] encodedBytes = byteArrayOutputStream.toByteArray(); - char[] charsEncoded = bytesToChars(encodedBytes); + byte[] unpaddedEncodedBytes = removeBase32Padding(encodedBytes); + char[] charsEncoded = bytesToChars(unpaddedEncodedBytes); - Arrays.fill(encodedBytes, (byte) 0); Arrays.fill(unencoded, (byte) 0); Arrays.fill(payload, (byte) 0); Arrays.fill(checksum, (byte) 0); + Arrays.fill(encodedBytes, (byte) 0); + Arrays.fill(unpaddedEncodedBytes, (byte) 0); // Clean byteArrayOutputStream internal buffer int size = byteArrayOutputStream.size(); From e474a46a6029462ad63e9391af1984c8339da87b Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Tue, 12 Sep 2023 18:07:46 +0800 Subject: [PATCH 14/20] fixup! Remove the use of `com.google.common.base.Function` and `com.google.common.primitives.Bytes`. --- src/main/java/org/stellar/sdk/TransactionBuilder.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/org/stellar/sdk/TransactionBuilder.java b/src/main/java/org/stellar/sdk/TransactionBuilder.java index b944be13b..8e55129dc 100644 --- a/src/main/java/org/stellar/sdk/TransactionBuilder.java +++ b/src/main/java/org/stellar/sdk/TransactionBuilder.java @@ -243,7 +243,7 @@ public Transaction build() { * A default implementation of sequence number generation which will derive a sequence number * based on sourceAccount's current sequence number + 1. */ - public static Function incrementedSequenceNumberFunc = + public static Function IncrementedSequenceNumberFunc = TransactionBuilderAccount::getIncrementedSequenceNumber; @Deprecated From 7592437078caa975f4450889696e6817259af428 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 13 Sep 2023 00:44:57 +0800 Subject: [PATCH 15/20] Remove the use of `com.google.common.collect.ImmutableList`. --- .../org/stellar/sdk/responses/EffectDeserializer.java | 2 -- .../effects/LiquidityPoolRevokedEffectResponse.java | 8 ++++---- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/main/java/org/stellar/sdk/responses/EffectDeserializer.java b/src/main/java/org/stellar/sdk/responses/EffectDeserializer.java index cc841b201..abcc12840 100644 --- a/src/main/java/org/stellar/sdk/responses/EffectDeserializer.java +++ b/src/main/java/org/stellar/sdk/responses/EffectDeserializer.java @@ -1,6 +1,5 @@ package org.stellar.sdk.responses; -import com.google.common.collect.ImmutableList; import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.JsonDeserializationContext; @@ -26,7 +25,6 @@ public EffectResponse deserialize( .registerTypeAdapter(LiquidityPoolID.class, new LiquidityPoolIDDeserializer()) .registerTypeAdapter(LiquidityPoolType.class, new LiquidityPoolTypeDeserializer()) .registerTypeAdapter(Predicate.class, new PredicateDeserializer()) - .registerTypeAdapter(ImmutableList.class, new ImmutableListDeserializer()) .create(); int type = json.getAsJsonObject().get("type_i").getAsInt(); diff --git a/src/main/java/org/stellar/sdk/responses/effects/LiquidityPoolRevokedEffectResponse.java b/src/main/java/org/stellar/sdk/responses/effects/LiquidityPoolRevokedEffectResponse.java index 228afd871..7aa8265a9 100644 --- a/src/main/java/org/stellar/sdk/responses/effects/LiquidityPoolRevokedEffectResponse.java +++ b/src/main/java/org/stellar/sdk/responses/effects/LiquidityPoolRevokedEffectResponse.java @@ -1,7 +1,7 @@ package org.stellar.sdk.responses.effects; -import com.google.common.collect.ImmutableList; import com.google.gson.annotations.SerializedName; +import java.util.List; /** * Represents liquidity_pool_revoked effect response. @@ -16,14 +16,14 @@ public class LiquidityPoolRevokedEffectResponse extends EffectResponse { protected final LiquidityPool liquidityPool; @SerializedName("reserves_revoked") - protected final ImmutableList reservesRevoked; + protected final List reservesRevoked; @SerializedName("shares_revoked") protected final String sharesRevoked; public LiquidityPoolRevokedEffectResponse( LiquidityPool liquidityPool, - ImmutableList reservesRevoked, + List reservesRevoked, String sharesRevoked) { this.liquidityPool = liquidityPool; this.reservesRevoked = reservesRevoked; @@ -34,7 +34,7 @@ public LiquidityPool getLiquidityPool() { return liquidityPool; } - public ImmutableList getReservesRevoked() { + public List getReservesRevoked() { return reservesRevoked; } From baf7b4cefa3604b481e1bc19da530934235e27ee Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 13 Sep 2023 01:54:09 +0800 Subject: [PATCH 16/20] remove com.google.guava:guava:32.1.2-android --- build.gradle | 3 --- .../stellar/sdk/InvokeHostFunctionOperation.java | 2 +- src/main/java/org/stellar/sdk/MemoHashAbstract.java | 6 +++--- src/main/java/org/stellar/sdk/MemoText.java | 6 +++--- .../sdk/PathPaymentStrictReceiveOperation.java | 10 ++++++---- .../stellar/sdk/PathPaymentStrictSendOperation.java | 10 ++++++---- .../java/org/stellar/sdk/SorobanDataBuilder.java | 2 +- src/main/java/org/stellar/sdk/SorobanServer.java | 2 +- src/main/java/org/stellar/sdk/Transaction.java | 6 +++--- .../java/org/stellar/sdk/TransactionBuilder.java | 4 ++-- .../java/org/stellar/sdk/requests/SSEStream.java | 2 +- .../org/stellar/sdk/SorobanDataBuilderTest.java | 6 +++--- .../org/stellar/sdk/TransactionBuilderTest.java | 13 ++++++++----- .../stellar/sdk/TransactionPreconditionsTest.java | 6 +++--- 14 files changed, 41 insertions(+), 37 deletions(-) diff --git a/build.gradle b/build.gradle index 8b8c34a4d..a45b0535b 100644 --- a/build.gradle +++ b/build.gradle @@ -71,9 +71,6 @@ dependencies { implementation "com.squareup.okhttp3:okhttp:${okhttpclientVersion}" implementation "com.squareup.okhttp3:okhttp-sse:${okhttpclientVersion}" implementation 'com.moandjiezana.toml:toml4j:0.7.2' - // use the android version because we don't want java 8 stuff - // TODO: Do we really need to introduce guava? - implementation 'com.google.guava:guava:32.1.2-android' implementation 'com.google.code.gson:gson:2.10.1' implementation 'net.i2p.crypto:eddsa:0.3.0' implementation 'commons-codec:commons-codec:1.16.0' diff --git a/src/main/java/org/stellar/sdk/InvokeHostFunctionOperation.java b/src/main/java/org/stellar/sdk/InvokeHostFunctionOperation.java index 56fe04b74..3a887ea74 100644 --- a/src/main/java/org/stellar/sdk/InvokeHostFunctionOperation.java +++ b/src/main/java/org/stellar/sdk/InvokeHostFunctionOperation.java @@ -5,12 +5,12 @@ import java.util.Arrays; import java.util.Collection; import java.util.List; -import javax.annotation.Nullable; import lombok.EqualsAndHashCode; import lombok.NonNull; import lombok.Singular; import lombok.Value; import lombok.experimental.SuperBuilder; +import org.jetbrains.annotations.Nullable; import org.stellar.sdk.xdr.ContractExecutable; import org.stellar.sdk.xdr.ContractExecutableType; import org.stellar.sdk.xdr.ContractIDPreimage; diff --git a/src/main/java/org/stellar/sdk/MemoHashAbstract.java b/src/main/java/org/stellar/sdk/MemoHashAbstract.java index d954e6c29..bb9752b84 100644 --- a/src/main/java/org/stellar/sdk/MemoHashAbstract.java +++ b/src/main/java/org/stellar/sdk/MemoHashAbstract.java @@ -1,7 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkArgument; - import java.util.Arrays; import lombok.NonNull; @@ -9,7 +7,9 @@ abstract class MemoHashAbstract extends Memo { protected byte[] bytes; public MemoHashAbstract(byte @NonNull [] bytes) { - checkArgument(bytes.length == 32, "bytes must be 32-bytes long."); + if (bytes.length != 32) { + throw new IllegalArgumentException("bytes must be 32-bytes long."); + } this.bytes = bytes; } diff --git a/src/main/java/org/stellar/sdk/MemoText.java b/src/main/java/org/stellar/sdk/MemoText.java index cad752e0b..5575f0ff0 100644 --- a/src/main/java/org/stellar/sdk/MemoText.java +++ b/src/main/java/org/stellar/sdk/MemoText.java @@ -1,7 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkArgument; - import lombok.NonNull; import org.stellar.sdk.xdr.MemoType; import org.stellar.sdk.xdr.XdrString; @@ -19,7 +17,9 @@ public MemoText(byte @NonNull [] text) { } public MemoText(@NonNull XdrString text) { - checkArgument(text.getBytes().length <= 28, "text cannot be more than 28-bytes long."); + if (text.getBytes().length > 28) { + throw new IllegalArgumentException("text cannot be more than 28-bytes long."); + } this.text = text; } diff --git a/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java b/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java index 3a537268d..49c4f2203 100644 --- a/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java +++ b/src/main/java/org/stellar/sdk/PathPaymentStrictReceiveOperation.java @@ -1,7 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkArgument; - import java.util.Arrays; import java.util.Objects; import lombok.NonNull; @@ -41,7 +39,9 @@ private PathPaymentStrictReceiveOperation( if (path == null) { this.path = new Asset[0]; } else { - checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); + if (path.length > 5) { + throw new IllegalArgumentException("The maximum number of assets in the path is 5"); + } this.path = path; } } @@ -172,7 +172,9 @@ public Builder( * @return Builder object so you can chain methods. */ public PathPaymentStrictReceiveOperation.Builder setPath(@NonNull Asset[] path) { - checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); + if (path.length > 5) { + throw new IllegalArgumentException("The maximum number of assets in the path is 5"); + } this.path = path; return this; } diff --git a/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java b/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java index e076eb6ad..85e92c499 100644 --- a/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java +++ b/src/main/java/org/stellar/sdk/PathPaymentStrictSendOperation.java @@ -1,7 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkArgument; - import java.util.Arrays; import java.util.Objects; import lombok.NonNull; @@ -41,7 +39,9 @@ private PathPaymentStrictSendOperation( if (path == null) { this.path = new Asset[0]; } else { - checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); + if (path.length > 5) { + throw new IllegalArgumentException("The maximum number of assets in the path is 5"); + } this.path = path; } } @@ -172,7 +172,9 @@ public Builder( * @return Builder object so you can chain methods. */ public PathPaymentStrictSendOperation.Builder setPath(@NonNull Asset[] path) { - checkArgument(path.length <= 5, "The maximum number of assets in the path is 5"); + if (path.length > 5) { + throw new IllegalArgumentException("The maximum number of assets in the path is 5"); + } this.path = path; return this; } diff --git a/src/main/java/org/stellar/sdk/SorobanDataBuilder.java b/src/main/java/org/stellar/sdk/SorobanDataBuilder.java index 23480f4ca..383560a5e 100644 --- a/src/main/java/org/stellar/sdk/SorobanDataBuilder.java +++ b/src/main/java/org/stellar/sdk/SorobanDataBuilder.java @@ -2,10 +2,10 @@ import java.io.IOException; import java.util.Collection; -import javax.annotation.Nullable; import lombok.Builder; import lombok.NonNull; import lombok.Value; +import org.jetbrains.annotations.Nullable; import org.stellar.sdk.xdr.ExtensionPoint; import org.stellar.sdk.xdr.Int64; import org.stellar.sdk.xdr.LedgerFootprint; diff --git a/src/main/java/org/stellar/sdk/SorobanServer.java b/src/main/java/org/stellar/sdk/SorobanServer.java index b038ab437..f1b6faa94 100644 --- a/src/main/java/org/stellar/sdk/SorobanServer.java +++ b/src/main/java/org/stellar/sdk/SorobanServer.java @@ -11,13 +11,13 @@ import java.util.Optional; import java.util.UUID; import java.util.concurrent.TimeUnit; -import javax.annotation.Nullable; import okhttp3.HttpUrl; import okhttp3.MediaType; import okhttp3.OkHttpClient; import okhttp3.Request; import okhttp3.RequestBody; import okhttp3.Response; +import org.jetbrains.annotations.Nullable; import org.stellar.sdk.requests.ClientIdentificationInterceptor; import org.stellar.sdk.requests.ResponseHandler; import org.stellar.sdk.requests.sorobanrpc.GetEventsRequest; diff --git a/src/main/java/org/stellar/sdk/Transaction.java b/src/main/java/org/stellar/sdk/Transaction.java index 4d2224e83..2a63facc8 100644 --- a/src/main/java/org/stellar/sdk/Transaction.java +++ b/src/main/java/org/stellar/sdk/Transaction.java @@ -1,7 +1,5 @@ package org.stellar.sdk; -import static com.google.common.base.Preconditions.checkArgument; - import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.Arrays; @@ -54,7 +52,9 @@ public class Transaction extends AbstractTransaction { this.mSourceAccount = sourceAccount; this.mSequenceNumber = sequenceNumber; this.mOperations = operations; - checkArgument(operations.length > 0, "At least one operation required"); + if (operations.length == 0) { + throw new IllegalArgumentException("At least one operation required"); + } this.mPreconditions = preconditions; this.mFee = fee; this.mMemo = memo != null ? memo : Memo.none(); diff --git a/src/main/java/org/stellar/sdk/TransactionBuilder.java b/src/main/java/org/stellar/sdk/TransactionBuilder.java index 8e55129dc..d31f56f83 100644 --- a/src/main/java/org/stellar/sdk/TransactionBuilder.java +++ b/src/main/java/org/stellar/sdk/TransactionBuilder.java @@ -1,9 +1,9 @@ package org.stellar.sdk; -import static com.google.common.collect.Lists.newArrayList; import static org.stellar.sdk.TransactionPreconditions.TIMEOUT_INFINITE; import java.math.BigInteger; +import java.util.ArrayList; import java.util.Collection; import java.util.List; import java.util.function.Function; @@ -41,7 +41,7 @@ public TransactionBuilder( mAccountConverter = accountConverter; mSourceAccount = sourceAccount; mNetwork = network; - mOperations = newArrayList(); + mOperations = new ArrayList<>(); mPreconditions = TransactionPreconditions.builder().build(); } diff --git a/src/main/java/org/stellar/sdk/requests/SSEStream.java b/src/main/java/org/stellar/sdk/requests/SSEStream.java index 7a1fe5629..b6d86bd9a 100644 --- a/src/main/java/org/stellar/sdk/requests/SSEStream.java +++ b/src/main/java/org/stellar/sdk/requests/SSEStream.java @@ -10,7 +10,6 @@ import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; -import javax.annotation.Nullable; import okhttp3.HttpUrl; import okhttp3.OkHttpClient; import okhttp3.Request; @@ -18,6 +17,7 @@ import okhttp3.internal.sse.RealEventSource; import okhttp3.sse.EventSource; import okhttp3.sse.EventSourceListener; +import org.jetbrains.annotations.Nullable; import org.stellar.sdk.Util; import org.stellar.sdk.responses.GsonSingleton; import org.stellar.sdk.responses.Pageable; diff --git a/src/test/java/org/stellar/sdk/SorobanDataBuilderTest.java b/src/test/java/org/stellar/sdk/SorobanDataBuilderTest.java index f55a4ae74..708b29a77 100644 --- a/src/test/java/org/stellar/sdk/SorobanDataBuilderTest.java +++ b/src/test/java/org/stellar/sdk/SorobanDataBuilderTest.java @@ -1,6 +1,6 @@ package org.stellar.sdk; -import static com.google.common.collect.ImmutableList.of; +import static java.util.Collections.singletonList; import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotSame; @@ -101,8 +101,8 @@ public void testConstructorFromSorobanTransactionData() { public void testSetProperties() { SorobanTransactionData actualData = new SorobanDataBuilder() - .setReadOnly(of(readOnly)) - .setReadWrite(of(readWrite)) + .setReadOnly(singletonList(readOnly)) + .setReadWrite(singletonList(readWrite)) .setRefundableFee(5) .setResources( new SorobanDataBuilder.Resources.ResourcesBuilder() diff --git a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java index 224359fdf..00303776b 100644 --- a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java +++ b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java @@ -1,10 +1,11 @@ package org.stellar.sdk; -import static com.google.common.collect.Lists.newArrayList; import static org.junit.Assert.*; +import com.sun.tools.javac.util.List; import java.io.IOException; import java.math.BigInteger; +import java.util.Collections; import org.junit.Test; import org.stellar.sdk.xdr.*; @@ -481,7 +482,7 @@ public void testBuilderExtraSigners() throws IOException { TransactionPreconditions.builder() .timeBounds( new TimeBounds(BigInteger.ZERO, TransactionPreconditions.TIMEOUT_INFINITE)) - .extraSigners(newArrayList(signerKey)) + .extraSigners(Collections.singletonList(signerKey)) .minSeqLedgerGap(5) .build()) .setBaseFee(Transaction.MIN_BASE_FEE) @@ -489,10 +490,12 @@ public void testBuilderExtraSigners() throws IOException { assertEquals( SignerKeyType.SIGNER_KEY_TYPE_ED25519_SIGNED_PAYLOAD, - newArrayList(transaction.getPreconditions().getExtraSigners()).get(0).getDiscriminant()); + transaction.getPreconditions().getExtraSigners().get(0).getDiscriminant()); assertArrayEquals( payload, - newArrayList(transaction.getPreconditions().getExtraSigners()) + transaction + .getPreconditions() + .getExtraSigners() .get(0) .getEd25519SignedPayload() .getPayload()); @@ -524,7 +527,7 @@ public void testBuilderFailsWhenTooManyExtraSigners() throws IOException { .timeBounds( new TimeBounds(BigInteger.ZERO, TransactionPreconditions.TIMEOUT_INFINITE)) .extraSigners( - newArrayList( + List.of( new SignerKey.Builder().build(), new SignerKey.Builder().build(), new SignerKey.Builder().build())) diff --git a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java index 5f5364fd9..d3301847d 100644 --- a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java +++ b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java @@ -1,11 +1,11 @@ package org.stellar.sdk; -import static com.google.common.collect.Lists.newArrayList; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; +import com.sun.tools.javac.util.List; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; @@ -122,7 +122,7 @@ public void itConvertsToV2Xdr() throws IOException { TransactionPreconditions.builder() .timeBounds(new TimeBounds(1, 2)) .minSeqNumber(3L) - .extraSigners(newArrayList(signerKey, signerKey, signerKey)) + .extraSigners(List.of(signerKey, signerKey, signerKey)) .build(); Preconditions xdr = preconditions.toXdr(); @@ -213,7 +213,7 @@ public void itChecksNonValidityOfExtraSignersSize() { TransactionPreconditions.builder() .timeBounds(new TimeBounds(1, 2)) .extraSigners( - newArrayList( + List.of( new SignerKey.Builder().build(), new SignerKey.Builder().build(), new SignerKey.Builder().build())) From b2f0cb067ccc945234eb328e6f705597d3872988 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 13 Sep 2023 14:34:08 +0800 Subject: [PATCH 17/20] empty commit, trigger a pipeline From cde613d4d8141fb84056f610a175894160418454 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 13 Sep 2023 15:12:00 +0800 Subject: [PATCH 18/20] clean up shadowJar config --- build.gradle | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/build.gradle b/build.gradle index a45b0535b..5d124bf88 100644 --- a/build.gradle +++ b/build.gradle @@ -50,17 +50,12 @@ shadowJar { exclude 'com.android.org.conscrypt' } relocate 'net.', 'shadow.net.' - relocate 'javax.annotation', 'shadow.javax.annotation' - relocate 'org.apache', 'shadow.org.apache' - relocate 'org.jvnet', 'shadow.org.jvnet' - relocate 'org.codehaus', 'shadow.org.codehaus' - relocate 'org.threeten', 'shadow.org.threeten' - relocate 'org.checkerframework', 'shadow.org.checkerframework' relocate 'okhttp3', 'shadow.okhttp3' relocate 'okio', 'shadow.okio' relocate 'kotlin', 'shadow.kotlin' relocate 'org.intellij', 'shadow.org.intellij' relocate 'org.jetbrains', 'shadow.org.jetbrains' + relocate 'org.apache', 'shadow.org.apache' } repositories { From cef2098ee03ece0b9cf3e3e7f123eaa16a16eb89 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 13 Sep 2023 21:55:38 +0800 Subject: [PATCH 19/20] empty commit, trigger a pipeline From 8a17a352164e7315aa4ae970c8044e1d23e40a3d Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Thu, 14 Sep 2023 17:43:02 +0800 Subject: [PATCH 20/20] fix import --- src/test/java/org/stellar/sdk/TransactionBuilderTest.java | 4 ++-- .../java/org/stellar/sdk/TransactionPreconditionsTest.java | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java index 00303776b..9819b826e 100644 --- a/src/test/java/org/stellar/sdk/TransactionBuilderTest.java +++ b/src/test/java/org/stellar/sdk/TransactionBuilderTest.java @@ -2,9 +2,9 @@ import static org.junit.Assert.*; -import com.sun.tools.javac.util.List; import java.io.IOException; import java.math.BigInteger; +import java.util.Arrays; import java.util.Collections; import org.junit.Test; import org.stellar.sdk.xdr.*; @@ -527,7 +527,7 @@ public void testBuilderFailsWhenTooManyExtraSigners() throws IOException { .timeBounds( new TimeBounds(BigInteger.ZERO, TransactionPreconditions.TIMEOUT_INFINITE)) .extraSigners( - List.of( + Arrays.asList( new SignerKey.Builder().build(), new SignerKey.Builder().build(), new SignerKey.Builder().build())) diff --git a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java index d3301847d..af65395e0 100644 --- a/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java +++ b/src/test/java/org/stellar/sdk/TransactionPreconditionsTest.java @@ -5,10 +5,10 @@ import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; -import com.sun.tools.javac.util.List; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; +import java.util.Arrays; import org.junit.Test; import org.stellar.sdk.xdr.Duration; import org.stellar.sdk.xdr.Int64; @@ -122,7 +122,7 @@ public void itConvertsToV2Xdr() throws IOException { TransactionPreconditions.builder() .timeBounds(new TimeBounds(1, 2)) .minSeqNumber(3L) - .extraSigners(List.of(signerKey, signerKey, signerKey)) + .extraSigners(Arrays.asList(signerKey, signerKey, signerKey)) .build(); Preconditions xdr = preconditions.toXdr(); @@ -213,7 +213,7 @@ public void itChecksNonValidityOfExtraSignersSize() { TransactionPreconditions.builder() .timeBounds(new TimeBounds(1, 2)) .extraSigners( - List.of( + Arrays.asList( new SignerKey.Builder().build(), new SignerKey.Builder().build(), new SignerKey.Builder().build()))