From 1a200ddba8c6d1ede379ba2b4363dddeccbda607 Mon Sep 17 00:00:00 2001 From: overcat <4catcode@gmail.com> Date: Wed, 5 Feb 2020 14:36:07 +0800 Subject: [PATCH] feat: add support for `/accounts` end-point with ?signer and ?asset filters. --- .../sdk/requests/AccountsRequestBuilder.java | 34 +++++++++++++++++++ .../stellar/sdk/requests/RequestBuilder.java | 34 ++++++++++++++----- .../requests/AccountsRequestBuilderTest.java | 22 +++++++++++- 3 files changed, 80 insertions(+), 10 deletions(-) diff --git a/src/main/java/org/stellar/sdk/requests/AccountsRequestBuilder.java b/src/main/java/org/stellar/sdk/requests/AccountsRequestBuilder.java index bca3e9507..c99c0845d 100644 --- a/src/main/java/org/stellar/sdk/requests/AccountsRequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/AccountsRequestBuilder.java @@ -5,6 +5,7 @@ import okhttp3.OkHttpClient; import okhttp3.Request; import okhttp3.Response; +import org.stellar.sdk.Asset; import org.stellar.sdk.responses.AccountResponse; import org.stellar.sdk.responses.Page; @@ -14,6 +15,9 @@ * Builds requests connected to accounts. */ public class AccountsRequestBuilder extends RequestBuilder { + private static final String ASSET_PARAMETER_NAME = "asset"; + private static final String SIGNER_PARAMETER_NAME = "signer"; + public AccountsRequestBuilder(OkHttpClient httpClient, HttpUrl serverURI) { super(httpClient, serverURI, "accounts"); } @@ -44,6 +48,36 @@ public AccountResponse account(String account) throws IOException { return this.account(this.buildUri()); } + /** + * Returns all accounts that contain a specific signer. + * + * @param signer Account ID + * @return current {@link AccountsRequestBuilder} instance + * @see Accounts + */ + public AccountsRequestBuilder forSigner(String signer) { + if (uriBuilder.build().queryParameter(ASSET_PARAMETER_NAME) != null) { + throw new RuntimeException("cannot set both signer and asset"); + } + uriBuilder.setQueryParameter(SIGNER_PARAMETER_NAME, signer); + return this; + } + + /** + * Returns all accounts who are trustees to a specific asset. + * + * @param asset An issued asset + * @return current {@link AccountsRequestBuilder} instance + * @see Accounts + */ + public AccountsRequestBuilder forAsset(Asset asset) { + if (uriBuilder.build().queryParameter(SIGNER_PARAMETER_NAME) != null) { + throw new RuntimeException("cannot set both signer and asset"); + } + setAssetParameter(ASSET_PARAMETER_NAME, asset); + return this; + } + /** * Requests specific uri and returns {@link Page} of {@link AccountResponse}. * This method is helpful for getting the next set of results. diff --git a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java index 2c17a34b8..653c29e8b 100644 --- a/src/main/java/org/stellar/sdk/requests/RequestBuilder.java +++ b/src/main/java/org/stellar/sdk/requests/RequestBuilder.java @@ -79,25 +79,41 @@ public RequestBuilder order(Order direction) { /** * Sets a parameter consisting of a comma separated list of assets on the request. - * @param name the name of the query parameter + * + * @param name the name of the query parameter * @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(); for (Asset asset : assets) { - if (asset instanceof AssetTypeNative) { - assetStrings.add("native"); - } else if (asset instanceof AssetTypeCreditAlphaNum) { - AssetTypeCreditAlphaNum creditAsset = (AssetTypeCreditAlphaNum) asset; - assetStrings.add(creditAsset.getCode()+":"+creditAsset.getIssuer()); - } else { - throw new RuntimeException("unsupported asset "+ asset.getType()); - } + assetStrings.add(buildAssetParameter(asset)); } uriBuilder.setQueryParameter(name, Joiner.on(",").join(assetStrings)); return this; } + /** + * Sets a parameter consisting of an asset represented as "assetCode:assetIssue" on the request. + * + * @param name the name of the query parameter + * @param asset the asset to be serialized into the query parameter value + */ + public RequestBuilder setAssetParameter(String name, Asset asset) { + uriBuilder.setQueryParameter(name, buildAssetParameter(asset)); + return this; + } + + private String buildAssetParameter(Asset asset) { + if (asset instanceof AssetTypeNative) { + return "native"; + } else if (asset instanceof AssetTypeCreditAlphaNum) { + AssetTypeCreditAlphaNum creditAsset = (AssetTypeCreditAlphaNum) asset; + return creditAsset.getCode() + ":" + creditAsset.getIssuer(); + } else { + throw new RuntimeException("unsupported asset " + asset.getType()); + } + } + HttpUrl buildUri() { if (segments.size() > 0) { for (String segment : segments) { diff --git a/src/test/java/org/stellar/sdk/requests/AccountsRequestBuilderTest.java b/src/test/java/org/stellar/sdk/requests/AccountsRequestBuilderTest.java index 627327086..d4b446222 100644 --- a/src/test/java/org/stellar/sdk/requests/AccountsRequestBuilderTest.java +++ b/src/test/java/org/stellar/sdk/requests/AccountsRequestBuilderTest.java @@ -2,7 +2,8 @@ import okhttp3.HttpUrl; import org.junit.Test; -import org.stellar.sdk.Network; +import org.stellar.sdk.Asset; +import org.stellar.sdk.AssetTypeCreditAlphaNum4; import org.stellar.sdk.Server; import static org.junit.Assert.assertEquals; @@ -18,4 +19,23 @@ public void testAccounts() { .buildUri(); assertEquals("https://horizon-testnet.stellar.org/accounts?cursor=13537736921089&limit=200&order=asc", uri.toString()); } + + @Test + public void testForSigner() { + Server server = new Server("https://horizon-testnet.stellar.org"); + HttpUrl uri = server.accounts() + .forSigner("GDSBCQO34HWPGUGQSP3QBFEXVTSR2PW46UIGTHVWGWJGQKH3AFNHXHXN") + .buildUri(); + assertEquals("https://horizon-testnet.stellar.org/accounts?signer=GDSBCQO34HWPGUGQSP3QBFEXVTSR2PW46UIGTHVWGWJGQKH3AFNHXHXN", uri.toString()); + } + + @Test + public void testForAsset() { + Server server = new Server("https://horizon-testnet.stellar.org"); + Asset asset = new AssetTypeCreditAlphaNum4("USD", "GDVDKQFP665JAO7A2LSHNLQIUNYNAAIGJ6FYJVMG4DT3YJQQJSRBLQDG"); + HttpUrl uri = server.accounts() + .forAsset(asset) + .buildUri(); + assertEquals("https://horizon-testnet.stellar.org/accounts?asset=USD%3AGDVDKQFP665JAO7A2LSHNLQIUNYNAAIGJ6FYJVMG4DT3YJQQJSRBLQDG", uri.toString()); + } }