From e52a0427bda4d0a7aca88794dd15cffc32718174 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Mon, 12 Aug 2024 13:47:43 +0530 Subject: [PATCH 01/11] feat: fetch asset by query implementation and test cases --- .../com/contentstack/sdk/AssetTestCase.java | 75 +++++++++++++++++++ .../com/contentstack/sdk/AssetLibrary.java | 15 ++++ 2 files changed, 90 insertions(+) diff --git a/contentstack/src/androidTest/java/com/contentstack/sdk/AssetTestCase.java b/contentstack/src/androidTest/java/com/contentstack/sdk/AssetTestCase.java index 7137b885..3f46ad7f 100644 --- a/contentstack/src/androidTest/java/com/contentstack/sdk/AssetTestCase.java +++ b/contentstack/src/androidTest/java/com/contentstack/sdk/AssetTestCase.java @@ -9,9 +9,11 @@ import org.junit.runners.MethodSorters; import java.util.List; +import java.util.concurrent.CountDownLatch; import static junit.framework.Assert.assertTrue; import static junit.framework.TestCase.assertEquals; +import static junit.framework.TestCase.assertNotNull; import androidx.test.InstrumentationRegistry; import androidx.test.core.app.ApplicationProvider; @@ -22,6 +24,8 @@ public class AssetTestCase { private final String TAG = AssetTestCase.class.getSimpleName(); private static String assetUid = BuildConfig.assetUID; private static Stack stack; + private static CountDownLatch latch; + @BeforeClass public static void oneTimeSetUp() throws Exception { @@ -191,4 +195,75 @@ public void test_GCP_NA() throws Exception { stack = Contentstack.stack(appContext, DEFAULT_API_KEY, DEFAULT_DELIVERY_TOKEN, DEFAULT_ENV, config); } + @Test + public void test_I_fetch_asset_by_title() { + final AssetLibrary assetLibrary = stack.assetLibrary().where("title", "iot-icon.png"); + assetLibrary.fetchAll(new FetchAssetsCallback() { + @Override + public void onCompletion(ResponseType responseType, List assets, Error error) { + if (error == null) { + for (Asset asset : assets) { + Log.d("RESULT:", "resp" + asset.json); + } + } + } + }); + } + + @Test + public void test_J_fetch_asset_by_tags() { + final AssetLibrary assetLibrary = stack.assetLibrary().where("tags","tag1"); + assetLibrary.fetchAll(new FetchAssetsCallback() { + @Override + public void onCompletion(ResponseType responseType, List assets, Error error) { + if (error == null) { + for( Asset asset : assets){ + Log.d("RESULT:", "resp" + asset.json); + } + assertTrue(assets.size()>0); + } + } + }); + } + + @Test + public void test_K_fetch_asset_by_description() { + final AssetLibrary assetLibrary= stack.assetLibrary().where("description","Page1"); + assetLibrary.fetchAll(new FetchAssetsCallback() { + @Override + public void onCompletion(ResponseType responseType, List assets, Error error) { + for(Asset asset : assets){ + Log.d("RESULT:", "resp" + asset.toJSON()); + } + assertTrue(assets.size()>0); + } + }); + } + + @Test + public void test_L_fetch_asset_invalid() { + final AssetLibrary assetLibrary = stack.assetLibrary().where("title",null); + assetLibrary.fetchAll(new FetchAssetsCallback() { + @Override + public void onCompletion(ResponseType responseType, List assets, Error error) { + Log.e("RESULT:", "ERROR:"+ error.errorMessage); + } + }); + + } + + @Test + public void test_M_fetch_asset_empty_title() { + final AssetLibrary assetLibrary = stack.assetLibrary().where("title",""); + assetLibrary.fetchAll(new FetchAssetsCallback() { + @Override + public void onCompletion(ResponseType responseType, List assets, Error error) { + for(Asset asset : assets){ + Log.d("RESULT:", "resp: " + asset.toJSON()); + } + assertEquals(0, assets.size()); + } + }); + } + } diff --git a/contentstack/src/main/java/com/contentstack/sdk/AssetLibrary.java b/contentstack/src/main/java/com/contentstack/sdk/AssetLibrary.java index 48a081d8..973a3c08 100644 --- a/contentstack/src/main/java/com/contentstack/sdk/AssetLibrary.java +++ b/contentstack/src/main/java/com/contentstack/sdk/AssetLibrary.java @@ -452,5 +452,20 @@ public AssetLibrary includeMetadata() { } return this; } + public AssetLibrary where(String key, String value) { + if (value != null) { + try { + JSONObject queryParams = new JSONObject(); + queryParams.put(key, value); + urlQueries.put("query", queryParams); + } catch (JSONException e) { + Log.e(TAG, "JSON error: " + e.getLocalizedMessage()); + } + } else { + Log.e(TAG, "Value for key '" + key + "' is null. Skipping addition to query."); + } + return this; + } + } From b786d4e93034cc574dcb5c6f906545071c7913cc Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Tue, 13 Aug 2024 10:50:49 +0530 Subject: [PATCH 02/11] chore: version bump --- CHANGELOG.md | 8 ++++++++ contentstack/build.gradle | 2 +- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ca4d346a..b5d2e1c1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ # CHANGELOG +## Version 3.16.1 + +### Date: 21-August-2024 + +- Fetch Asset by query + +--- + ## Version 3.16.0 ### Date: 31-July-2024 diff --git a/contentstack/build.gradle b/contentstack/build.gradle index 878f55f8..68257fdc 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -10,7 +10,7 @@ android.buildFeatures.buildConfig true mavenPublishing { publishToMavenCentral(SonatypeHost.DEFAULT) signAllPublications() - coordinates("com.contentstack.sdk", "android", "3.16.0") + coordinates("com.contentstack.sdk", "android", "3.16.1") pom { name = "contentstack-android" From 980244dd244cc309b97aaf6a681ac17f534d33f5 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Wed, 14 Aug 2024 14:20:46 +0530 Subject: [PATCH 03/11] chore: testcases are added for early access --- .../sdk/ExampleInstrumentedTest.java | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java b/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java index c512193a..2fe024f6 100644 --- a/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java +++ b/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java @@ -2,6 +2,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertTrue; import android.content.Context; import android.util.Log; @@ -98,4 +99,30 @@ public void onCompletion(SyncStack syncStack, Error error) { }); assertNotNull(stack.syncParams); } + + @Test + public void testEarlyAccess() throws Exception { + Context ctx = ApplicationProvider.getApplicationContext(); + Config config = new Config(); + String[] earlyAccess = {"Taxonomy"}; + config.earlyAccess(earlyAccess); + stack = Contentstack.stack(ctx, apiKey, deliveryToken, environment, config); + assertEquals(earlyAccess[0], config.earlyAccess[0]); + assertNotNull(stack.localHeader.containsKey("x-header-ea")); + assertEquals("Taxonomy", stack.localHeader.get("x-header-ea")); + } + + @Test + public void testConfigEarlyAccessMultipleFeature() throws Exception { + Context ctx = ApplicationProvider.getApplicationContext(); + Config config = new Config(); + String[] earlyAccess = {"Taxonomy", "Teams", "Terms", "LivePreview"}; + config.earlyAccess(earlyAccess); + stack = Contentstack. stack(ctx, apiKey, deliveryToken, environment, config); + assertEquals(4, stack.localHeader.keySet().size()); + assertEquals(earlyAccess[1], config.earlyAccess[1]); + assertTrue(stack.localHeader.containsKey("x-header-ea")); + assertEquals("Taxonomy,Teams,Terms,LivePreview", stack.localHeader.get("x-header-ea")); + } + } \ No newline at end of file From c8f1e08d76417fa14af533a480fd11f4d4e3b426 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Mon, 19 Aug 2024 11:53:30 +0530 Subject: [PATCH 04/11] chore : indentation fixing --- .../java/com/contentstack/sdk/ExampleInstrumentedTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java b/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java index 2fe024f6..da0d480e 100644 --- a/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java +++ b/contentstack/src/androidTest/java/com/contentstack/sdk/ExampleInstrumentedTest.java @@ -118,7 +118,7 @@ public void testConfigEarlyAccessMultipleFeature() throws Exception { Config config = new Config(); String[] earlyAccess = {"Taxonomy", "Teams", "Terms", "LivePreview"}; config.earlyAccess(earlyAccess); - stack = Contentstack. stack(ctx, apiKey, deliveryToken, environment, config); + stack = Contentstack.stack(ctx, apiKey, deliveryToken, environment, config); assertEquals(4, stack.localHeader.keySet().size()); assertEquals(earlyAccess[1], config.earlyAccess[1]); assertTrue(stack.localHeader.containsKey("x-header-ea")); From 0a88408a479312e69cb3c6d4a7403d20f4e182f4 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Tue, 20 Aug 2024 12:29:05 +0530 Subject: [PATCH 05/11] fix: SRE issue --- .../src/main/java/com/contentstack/sdk/SDKUtil.java | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/contentstack/src/main/java/com/contentstack/sdk/SDKUtil.java b/contentstack/src/main/java/com/contentstack/sdk/SDKUtil.java index 72cf092f..8220aa46 100755 --- a/contentstack/src/main/java/com/contentstack/sdk/SDKUtil.java +++ b/contentstack/src/main/java/com/contentstack/sdk/SDKUtil.java @@ -150,12 +150,9 @@ public String getSHAFromString(String value) { // Create Hex String // deepcode ignore ApiMigration: StringBuffer hexString = new StringBuffer(); - for (int i = 0; i < messageDigest.length; i++) { - String hex = Integer.toHexString(0xFF & messageDigest[i]); - if (hex.length() == 1) { - hexString.append('0'); - } - hexString.append(hex); + for (byte b : messageDigest) { + // Format each byte as two-digit hexadecimal + hexString.append(String.format("%02X", b)); } return hexString.toString(); From c7e1b4e067903e12027f433fdc767b64f07a7f53 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Thu, 27 Jun 2024 15:59:51 +0530 Subject: [PATCH 06/11] feat : variants implementation and testcases --- contentstack/build.gradle | 12 +++---- .../com/contentstack/sdk/EntryTestCase.java | 25 +++++++++++++ .../main/java/com/contentstack/sdk/Entry.java | 36 +++++++++++++++++++ 3 files changed, 67 insertions(+), 6 deletions(-) diff --git a/contentstack/build.gradle b/contentstack/build.gradle index 878f55f8..f15adf45 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -118,12 +118,12 @@ android { testCoverageEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' - buildConfigField "String", "host", localProperties['host'] - buildConfigField "String", "APIKey", localProperties['APIKey'] - buildConfigField "String", "deliveryToken", localProperties['deliveryToken'] - buildConfigField "String", "environment", localProperties['environment'] - buildConfigField "String", "contentTypeUID", localProperties['contentType'] - buildConfigField "String", "assetUID", localProperties['assetUid'] + buildConfigField "String", "host", localProperties['host'] + buildConfigField "String", "APIKey", localProperties['APIKey'] + buildConfigField "String", "deliveryToken", localProperties['deliveryToken'] + buildConfigField "String", "environment", localProperties['environment'] + buildConfigField "String", "contentTypeUID", localProperties['contentType'] + buildConfigField "String", "assetUID", localProperties['assetUid'] } release { minifyEnabled false diff --git a/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java b/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java index b9b40beb..a2c4661c 100644 --- a/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java +++ b/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java @@ -27,6 +27,9 @@ public class EntryTestCase { private static final String CONTENT_TYPE_UID = BuildConfig.contentTypeUID; private static CountDownLatch latch; private static Stack stack; + private static String variantUID = BuildConfig.variantUID; + private static String variantEntryUID = BuildConfig.variantEntryUID; + private static String[] variantsUID = BuildConfig.variantsUID; @BeforeClass @@ -319,4 +322,26 @@ public void onCompletion(ResponseType responseType, Error error) { latch.await(); } + @Test + public void VariantsTestSingleUid(){ + final Entry entry = stack.contentType("author").entry(variantEntryUID).variants(variantUID); + entry.fetch(new EntryResultCallBack() { + @Override + public void onCompletion(ResponseType responseType, Error error) { + assertEquals(variantUID, entry.getHeaders().get("x-cs-variant-uid")); + System.out.println(entry.toJSON()); + } + }); + } + @Test + public void VariantsTestArray(){ + final Entry entry = stack.contentType("author").entry(variantEntryUID).variants(variantsUID); + entry.fetch(new EntryResultCallBack() { + @Override + public void onCompletion(ResponseType responseType, Error error) { + System.out.println(entry.toJSON()); + } + }); + } + } \ No newline at end of file diff --git a/contentstack/src/main/java/com/contentstack/sdk/Entry.java b/contentstack/src/main/java/com/contentstack/sdk/Entry.java index f315392c..dd0e6696 100755 --- a/contentstack/src/main/java/com/contentstack/sdk/Entry.java +++ b/contentstack/src/main/java/com/contentstack/sdk/Entry.java @@ -1494,4 +1494,40 @@ public Entry includeMetadata() { } return this; } + /** + * method variants + * memberof Entry + * description The variant header will be added to client + * returns {Entry} + * example + * import contentstack from '@contentstack/delivery-sdk' + * + * Stack stack = contentstack.Stack("apiKey", "deliveryToken", + * "environment"); + * Entry entry = + * stack.contentType("user").entry("entry_uid").variant("variant_uid").fetch(); + */ + public Entry variants(String variants){ + if (variants != null && variants.length() > 0) { + this.localHeader.put("x-cs-variant-uid", variants.trim()); + } + return this; + + } + public Entry variants(String[] variants){ + if (variants != null && variants.length > 0) { + List variantList = new ArrayList<>(); + for (String variant : variants) { + if(variant != null && !variant.trim().isEmpty()) + variantList.add(variant.trim()); + } + if(!variantList.isEmpty()){ + this.localHeader.put("x-cs-variant-uid", String.join(", ", variantList)); + } + } + return this; + } + public ArrayMap getHeaders() { + return localHeader; + } } From 5b2dc75b74101fe1ce5a3d35e79f3204271142ce Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Tue, 20 Aug 2024 15:21:40 +0530 Subject: [PATCH 07/11] chore: version bump done need to add changelog --- contentstack/build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contentstack/build.gradle b/contentstack/build.gradle index f15adf45..ca63fb19 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -10,7 +10,7 @@ android.buildFeatures.buildConfig true mavenPublishing { publishToMavenCentral(SonatypeHost.DEFAULT) signAllPublications() - coordinates("com.contentstack.sdk", "android", "3.16.0") + coordinates("com.contentstack.sdk", "android", "4.0.0") pom { name = "contentstack-android" From d51bff207faed28164df9e3b2493dabee5d9a08a Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Fri, 23 Aug 2024 16:04:20 +0530 Subject: [PATCH 08/11] version bump --- CHANGELOG.md | 8 ++++++++ contentstack/build.gradle | 2 +- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b5d2e1c1..b6cb5103 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ # CHANGELOG +## Version 3.16.2 + +### Date: 28-August-2024 + +- Early access header test + +--- + ## Version 3.16.1 ### Date: 21-August-2024 diff --git a/contentstack/build.gradle b/contentstack/build.gradle index 68257fdc..7cbb41e8 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -10,7 +10,7 @@ android.buildFeatures.buildConfig true mavenPublishing { publishToMavenCentral(SonatypeHost.DEFAULT) signAllPublications() - coordinates("com.contentstack.sdk", "android", "3.16.1") + coordinates("com.contentstack.sdk", "android", "3.16.2") pom { name = "contentstack-android" From 62ad2457049c419de398e95df2662c46f29a9b27 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Mon, 2 Sep 2024 17:56:57 +0530 Subject: [PATCH 09/11] chore: discarding version bump --- CHANGELOG.md | 8 -------- contentstack/build.gradle | 2 +- 2 files changed, 1 insertion(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b6cb5103..b5d2e1c1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,13 +1,5 @@ # CHANGELOG -## Version 3.16.2 - -### Date: 28-August-2024 - -- Early access header test - ---- - ## Version 3.16.1 ### Date: 21-August-2024 diff --git a/contentstack/build.gradle b/contentstack/build.gradle index 7cbb41e8..68257fdc 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -10,7 +10,7 @@ android.buildFeatures.buildConfig true mavenPublishing { publishToMavenCentral(SonatypeHost.DEFAULT) signAllPublications() - coordinates("com.contentstack.sdk", "android", "3.16.2") + coordinates("com.contentstack.sdk", "android", "3.16.1") pom { name = "contentstack-android" From 56eb5a98d05cfce735a7e796703c3d3c5fba50dc Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Wed, 11 Sep 2024 17:53:22 +0530 Subject: [PATCH 10/11] chore: buildconfig contains variant properties --- contentstack/build.gradle | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/contentstack/build.gradle b/contentstack/build.gradle index ca63fb19..a225af9d 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -112,6 +112,8 @@ android { def localProperties = new Properties() localProperties.load(new FileInputStream(rootProject.file("local.properties"))) + def variantsArray = localProperties['variantsUID']?.split(",")?.collect { it.trim() } + def variantsAsArrayString = 'new String[] {' + variantsArray.collect { "\"$it\"" }.join(", ") + '}' buildTypes { debug { debuggable true @@ -124,6 +126,9 @@ android { buildConfigField "String", "environment", localProperties['environment'] buildConfigField "String", "contentTypeUID", localProperties['contentType'] buildConfigField "String", "assetUID", localProperties['assetUid'] + buildConfigField "String", "variantUID", localProperties['variantUID'] + buildConfigField "String", "variantEntryUID", localProperties['variantEntryUID'] + buildConfigField "String[]", "variantsUID", variantsAsArrayString } release { minifyEnabled false From d547e50c7ffb84a79cf9acdad38db46eaf82fab7 Mon Sep 17 00:00:00 2001 From: reeshika-h Date: Thu, 12 Sep 2024 11:49:06 +0530 Subject: [PATCH 11/11] fix: sca-scan workflow --- contentstack/build.gradle | 24 +++++++++++-------- .../com/contentstack/sdk/EntryTestCase.java | 4 ++-- 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/contentstack/build.gradle b/contentstack/build.gradle index a225af9d..eaccd3e0 100755 --- a/contentstack/build.gradle +++ b/contentstack/build.gradle @@ -112,22 +112,26 @@ android { def localProperties = new Properties() localProperties.load(new FileInputStream(rootProject.file("local.properties"))) - def variantsArray = localProperties['variantsUID']?.split(",")?.collect { it.trim() } - def variantsAsArrayString = 'new String[] {' + variantsArray.collect { "\"$it\"" }.join(", ") + '}' + def getPropertyOrEmpty = { key -> + def value = localProperties.getProperty(key) + return value != null ? "$value" : "\"\"" + } + def variantsArray = localProperties.getProperty('variantsUID')?.split(",")?.collect { it.trim() } + def variantsAsArrayString = variantsArray ? 'new String[] {' + variantsArray.collect { "\"$it\"" }.join(", ") + '}' : "new String[0]" buildTypes { debug { debuggable true testCoverageEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' - buildConfigField "String", "host", localProperties['host'] - buildConfigField "String", "APIKey", localProperties['APIKey'] - buildConfigField "String", "deliveryToken", localProperties['deliveryToken'] - buildConfigField "String", "environment", localProperties['environment'] - buildConfigField "String", "contentTypeUID", localProperties['contentType'] - buildConfigField "String", "assetUID", localProperties['assetUid'] - buildConfigField "String", "variantUID", localProperties['variantUID'] - buildConfigField "String", "variantEntryUID", localProperties['variantEntryUID'] + buildConfigField "String", "host", getPropertyOrEmpty('host') + buildConfigField "String", "APIKey", getPropertyOrEmpty('APIKey') + buildConfigField "String", "deliveryToken", getPropertyOrEmpty('deliveryToken') + buildConfigField "String", "environment", getPropertyOrEmpty('environment') + buildConfigField "String", "contentTypeUID", getPropertyOrEmpty('contentType') + buildConfigField "String", "assetUID", getPropertyOrEmpty('assetUid') + buildConfigField "String", "variantUID", getPropertyOrEmpty('variantUID') + buildConfigField "String", "variantEntryUID", getPropertyOrEmpty('variantEntryUID') buildConfigField "String[]", "variantsUID", variantsAsArrayString } release { diff --git a/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java b/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java index a2c4661c..7a78dad4 100644 --- a/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java +++ b/contentstack/src/androidTest/java/com/contentstack/sdk/EntryTestCase.java @@ -324,7 +324,7 @@ public void onCompletion(ResponseType responseType, Error error) { @Test public void VariantsTestSingleUid(){ - final Entry entry = stack.contentType("author").entry(variantEntryUID).variants(variantUID); + final Entry entry = stack.contentType("product").entry(variantEntryUID).variants(variantUID); entry.fetch(new EntryResultCallBack() { @Override public void onCompletion(ResponseType responseType, Error error) { @@ -335,7 +335,7 @@ public void onCompletion(ResponseType responseType, Error error) { } @Test public void VariantsTestArray(){ - final Entry entry = stack.contentType("author").entry(variantEntryUID).variants(variantsUID); + final Entry entry = stack.contentType("product").entry(variantEntryUID).variants(variantsUID); entry.fetch(new EntryResultCallBack() { @Override public void onCompletion(ResponseType responseType, Error error) {