Skip to content

Commit

Permalink
Revert "Remove the dependency on Guava. (#524)"
Browse files Browse the repository at this point in the history
This reverts commit 302aba5.
  • Loading branch information
overcat authored Sep 19, 2023
1 parent 302aba5 commit 757ede2
Show file tree
Hide file tree
Showing 136 changed files with 1,270 additions and 1,070 deletions.
11 changes: 9 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -50,12 +50,17 @@ 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 {
Expand All @@ -66,9 +71,11 @@ 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'

testImplementation 'org.mockito:mockito-core:5.5.0'
testImplementation "com.squareup.okhttp3:mockwebserver:${okhttpclientVersion}"
Expand Down
23 changes: 13 additions & 10 deletions src/main/java/org/stellar/sdk/AbstractTransaction.java
Original file line number Diff line number Diff line change
@@ -1,27 +1,28 @@
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.Collections;
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;
import org.stellar.sdk.xdr.TransactionEnvelope;
import org.stellar.sdk.xdr.TransactionSignaturePayload;

public abstract class AbstractTransaction {

protected final Network mNetwork;
protected final AccountConverter accountConverter;
protected List<DecoratedSignature> mSignatures;
public static final int MIN_BASE_FEE = 100;

AbstractTransaction(@NonNull AccountConverter accountConverter, @NonNull Network network) {
this.accountConverter = accountConverter;
this.mNetwork = network;
AbstractTransaction(AccountConverter accountConverter, Network network) {
this.accountConverter = checkNotNull(accountConverter, "accountConverter cannot be null");
this.mNetwork = checkNotNull(network, "network cannot be null");
this.mSignatures = new ArrayList<DecoratedSignature>();
}

Expand All @@ -30,7 +31,8 @@ public abstract class AbstractTransaction {
*
* @param signer {@link KeyPair} object representing a signer
*/
public void sign(@NonNull KeyPair signer) {
public void sign(KeyPair signer) {
checkNotNull(signer, "signer cannot be null");
byte[] txHash = this.hash();
mSignatures.add(signer.signDecorated(txHash));
}
Expand All @@ -40,7 +42,8 @@ public void sign(@NonNull KeyPair signer) {
*
* @param preimage the sha256 hash of preimage should be equal to signer hash
*/
public void sign(byte @NonNull [] preimage) {
public void sign(byte[] preimage) {
checkNotNull(preimage, "preimage cannot be null");
org.stellar.sdk.xdr.Signature signature = new org.stellar.sdk.xdr.Signature();
signature.setSignature(preimage);

Expand All @@ -63,7 +66,7 @@ public byte[] hash() {

/** Returns transaction hash encoded as a hexadecimal string. */
public String hashHex() {
return Util.bytesToHex(this.hash()).toLowerCase();
return BaseEncoding.base16().lowerCase().encode(this.hash());
}

/** Returns signature base. */
Expand Down Expand Up @@ -93,7 +96,7 @@ public AccountConverter getAccountConverter() {
* @return immutable list of signatures
*/
public List<DecoratedSignature> getSignatures() {
return Collections.unmodifiableList(mSignatures);
return ImmutableList.copyOf(mSignatures);
}

/**
Expand Down
17 changes: 9 additions & 8 deletions src/main/java/org/stellar/sdk/Account.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;

/**
* Represents an account in Stellar network with it's sequence number. Account object is required to
Expand All @@ -20,9 +21,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(@NonNull String accountId, @NonNull Long sequenceNumber) {
mAccountId = accountId;
mSequenceNumber = sequenceNumber;
public Account(String accountId, Long sequenceNumber) {
mAccountId = checkNotNull(accountId, "accountId cannot be null");
mSequenceNumber = checkNotNull(sequenceNumber, "sequenceNumber cannot be null");
}

@Override
Expand Down Expand Up @@ -56,7 +57,7 @@ public void incrementSequenceNumber() {
}

public int hashCode() {
return Objects.hash(this.mAccountId, this.mSequenceNumber);
return Objects.hashCode(this.mAccountId, this.mSequenceNumber);
}

@Override
Expand All @@ -66,7 +67,7 @@ public boolean equals(Object object) {
}

Account other = (Account) object;
return Objects.equals(this.mAccountId, other.mAccountId)
&& Objects.equals(this.mSequenceNumber, other.mSequenceNumber);
return Objects.equal(this.mAccountId, other.mAccountId)
&& Objects.equal(this.mSequenceNumber, other.mSequenceNumber);
}
}
15 changes: 8 additions & 7 deletions src/main/java/org/stellar/sdk/AccountMergeOperation.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;
import org.stellar.sdk.xdr.Operation.OperationBody;
import org.stellar.sdk.xdr.OperationType;

Expand All @@ -16,8 +17,8 @@ public class AccountMergeOperation extends Operation {

private final String destination;

private AccountMergeOperation(@NonNull String destination) {
this.destination = destination;
private AccountMergeOperation(String destination) {
this.destination = checkNotNull(destination, "destination cannot be null");
}

/** The account that receives the remaining XLM balance of the source account. */
Expand Down Expand Up @@ -78,7 +79,7 @@ public AccountMergeOperation build() {
}

public int hashCode() {
return Objects.hash(this.destination, this.getSourceAccount());
return Objects.hashCode(this.destination, this.getSourceAccount());
}

@Override
Expand All @@ -88,7 +89,7 @@ public boolean equals(Object object) {
}

AccountMergeOperation other = (AccountMergeOperation) object;
return Objects.equals(this.destination, other.destination)
&& Objects.equals(this.getSourceAccount(), other.getSourceAccount());
return Objects.equal(this.destination, other.destination)
&& Objects.equal(this.getSourceAccount(), other.getSourceAccount());
}
}
26 changes: 12 additions & 14 deletions src/main/java/org/stellar/sdk/AllowTrustOperation.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;
import org.stellar.sdk.xdr.*;

/**
Expand All @@ -20,12 +21,9 @@ public class AllowTrustOperation extends Operation {
private final boolean authorizeToMaintainLiabilities;

private AllowTrustOperation(
@NonNull String trustor,
@NonNull String assetCode,
boolean authorize,
boolean authorizeToMaintainLiabilities) {
this.trustor = trustor;
this.assetCode = assetCode;
String trustor, String assetCode, boolean authorize, boolean authorizeToMaintainLiabilities) {
this.trustor = checkNotNull(trustor, "trustor cannot be null");
this.assetCode = checkNotNull(assetCode, "assetCode cannot be null");
this.authorize = authorize;
this.authorizeToMaintainLiabilities = authorizeToMaintainLiabilities;
}
Expand Down Expand Up @@ -167,7 +165,7 @@ public AllowTrustOperation build() {

@Override
public int hashCode() {
return Objects.hash(
return Objects.hashCode(
this.getSourceAccount(),
this.assetCode,
this.authorize,
Expand All @@ -182,10 +180,10 @@ public boolean equals(Object object) {
}

AllowTrustOperation other = (AllowTrustOperation) object;
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());
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());
}
}
8 changes: 4 additions & 4 deletions src/main/java/org/stellar/sdk/AssetAmount.java
Original file line number Diff line number Diff line change
@@ -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")
Expand All @@ -24,7 +24,7 @@ public String getAmount() {
}

public int hashCode() {
return Objects.hash(asset, amount);
return Objects.hashCode(asset, amount);
}

@Override
Expand All @@ -34,7 +34,7 @@ public boolean equals(Object object) {
}

AssetAmount o = (AssetAmount) object;
return Objects.equals(this.getAsset(), o.getAsset())
&& Objects.equals(this.getAmount(), o.getAmount());
return Objects.equal(this.getAsset(), o.getAsset())
&& Objects.equal(this.getAmount(), o.getAmount());
}
}
11 changes: 7 additions & 4 deletions src/main/java/org/stellar/sdk/AssetTypeCreditAlphaNum.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;

/**
* Base class for AssetTypeCreditAlphaNum4 and AssetTypeCreditAlphaNum12 subclasses.
Expand All @@ -12,7 +13,9 @@ public abstract class AssetTypeCreditAlphaNum extends Asset {
protected final String mCode;
protected final String mIssuer;

public AssetTypeCreditAlphaNum(@NonNull String code, @NonNull String issuer) {
public AssetTypeCreditAlphaNum(String code, String issuer) {
checkNotNull(code, "code cannot be null");
checkNotNull(issuer, "issuer cannot be null");
mCode = code;
mIssuer = issuer;
}
Expand All @@ -34,7 +37,7 @@ public String toString() {

@Override
public int hashCode() {
return Objects.hash(this.mCode, this.mIssuer);
return Objects.hashCode(this.mCode, this.mIssuer);
}

@Override
Expand Down
4 changes: 2 additions & 2 deletions src/main/java/org/stellar/sdk/AssetTypePoolShare.java
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
package org.stellar.sdk;

import java.util.Objects;
import com.google.common.base.Objects;

/**
* Represents Stellar liquidity pool share asset - <a
Expand Down Expand Up @@ -34,7 +34,7 @@ public boolean equals(Object object) {
return false;
}

return (Objects.equals(((AssetTypePoolShare) object).getPoolId(), poolId));
return (Objects.equal(((AssetTypePoolShare) object).getPoolId(), poolId));
}

@Override
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;
import org.stellar.sdk.xdr.*;

public class BeginSponsoringFutureReservesOperation extends Operation {
Expand Down Expand Up @@ -58,9 +59,8 @@ public Builder(String sponsoredId) {
* @param sourceAccount The operation's source account.
* @return Builder object so you can chain methods.
*/
public BeginSponsoringFutureReservesOperation.Builder setSourceAccount(
@NonNull String sourceAccount) {
mSourceAccount = sourceAccount;
public BeginSponsoringFutureReservesOperation.Builder setSourceAccount(String sourceAccount) {
mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null");
return this;
}

Expand All @@ -77,7 +77,7 @@ public BeginSponsoringFutureReservesOperation build() {

@Override
public int hashCode() {
return Objects.hash(this.sponsoredId, this.getSourceAccount());
return Objects.hashCode(this.sponsoredId, this.getSourceAccount());
}

@Override
Expand All @@ -87,7 +87,7 @@ public boolean equals(Object object) {
}

BeginSponsoringFutureReservesOperation other = (BeginSponsoringFutureReservesOperation) object;
return Objects.equals(this.sponsoredId, other.sponsoredId)
&& Objects.equals(this.getSourceAccount(), other.getSourceAccount());
return Objects.equal(this.sponsoredId, other.sponsoredId)
&& Objects.equal(this.getSourceAccount(), other.getSourceAccount());
}
}
15 changes: 8 additions & 7 deletions src/main/java/org/stellar/sdk/BumpSequenceOperation.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package org.stellar.sdk;

import java.util.Objects;
import lombok.NonNull;
import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Objects;
import org.stellar.sdk.xdr.BumpSequenceOp;
import org.stellar.sdk.xdr.Int64;
import org.stellar.sdk.xdr.OperationType;
Expand Down Expand Up @@ -64,8 +65,8 @@ public Builder(long bumpTo) {
* @param sourceAccount The operation's source account.
* @return Builder object so you can chain methods.
*/
public BumpSequenceOperation.Builder setSourceAccount(@NonNull String sourceAccount) {
mSourceAccount = sourceAccount;
public BumpSequenceOperation.Builder setSourceAccount(String sourceAccount) {
mSourceAccount = checkNotNull(sourceAccount, "sourceAccount cannot be null");
return this;
}

Expand All @@ -81,7 +82,7 @@ public BumpSequenceOperation build() {

@Override
public int hashCode() {
return Objects.hash(this.bumpTo, this.getSourceAccount());
return Objects.hashCode(this.bumpTo, this.getSourceAccount());
}

@Override
Expand All @@ -91,7 +92,7 @@ public boolean equals(Object object) {
}

BumpSequenceOperation other = (BumpSequenceOperation) object;
return Objects.equals(this.bumpTo, other.bumpTo)
&& Objects.equals(this.getSourceAccount(), other.getSourceAccount());
return Objects.equal(this.bumpTo, other.bumpTo)
&& Objects.equal(this.getSourceAccount(), other.getSourceAccount());
}
}
Loading

0 comments on commit 757ede2

Please sign in to comment.