diff --git a/sample_client/res/layout/main.xml b/sample_client/res/layout/main.xml
index e9140c82..17832baa 100644
--- a/sample_client/res/layout/main.xml
+++ b/sample_client/res/layout/main.xml
@@ -34,17 +34,20 @@
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
+ android:enabled="false"
android:onClick="onClickHandler"
- android:text="@string/refresh"/>
+ android:text="@string/refresh"
+ android:visibility="invisible"/>
@@ -52,42 +55,45 @@
android:id="@+id/list_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
- android:layout_below="@+id/button_refresh"
android:layout_above="@+id/button_upload"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
- >
+ android:layout_below="@+id/button_refresh"
+ android:visibility="invisible">
+ android:visibility="invisible"/>
+ android:textSize="14sp"
+ android:visibility="invisible"/>
+ android:layout_alignParentRight="true"
+ android:enabled="false"
+ android:onClick="onClickHandler"
+ android:text="@string/delete_remote_file"
+ android:visibility="invisible"/>
+ android:enabled="false"
+ android:onClick="onClickHandler"
+ android:text="@string/download"
+ android:visibility="invisible"/>
+ android:textSize="14sp"
+ android:visibility="invisible"/>
+ android:enabled="false"
+ android:onClick="onClickHandler"
+ android:text="@string/delete_local_file"
+ android:visibility="invisible"/>
+
+
diff --git a/sample_client/src/com/owncloud/android/lib/sampleclient/MainActivity.java b/sample_client/src/com/owncloud/android/lib/sampleclient/MainActivity.java
index 79accbe8..d5c97a2b 100644
--- a/sample_client/src/com/owncloud/android/lib/sampleclient/MainActivity.java
+++ b/sample_client/src/com/owncloud/android/lib/sampleclient/MainActivity.java
@@ -31,6 +31,7 @@ import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
+import android.view.Gravity;
import android.view.View;
import android.widget.ListView;
import android.widget.TextView;
@@ -50,6 +51,9 @@ import com.owncloud.android.lib.resources.files.RemoteFile;
import com.owncloud.android.lib.resources.files.RemoveRemoteFileOperation;
import com.owncloud.android.lib.resources.files.UploadRemoteFileOperation;
+import org.json.JSONException;
+import org.json.JSONObject;
+
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
@@ -77,6 +81,8 @@ public class MainActivity extends Activity implements OnRemoteOperationListener,
private FilesArrayAdapter mFilesAdapter;
private View mFrame;
+
+ private static final String NODE_VERSION = "version";
/** Called when the activity is first created. */
@Override
@@ -160,27 +166,93 @@ public class MainActivity extends Activity implements OnRemoteOperationListener,
private void startCheck() {
+ String serverAddress = ((TextView) findViewById(R.id.server_address)).getText().toString();
+
+ if (serverAddress.equals("")) {
+ Toast toast = Toast.makeText(getApplicationContext(),
+ "Introduce a server address", Toast.LENGTH_LONG);
+
+ toast.setGravity(Gravity.CENTER,0,0);
+
+ toast.show();
+
+ return;
+ }
+
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
- .url("")
+ .url(serverAddress + "/status.php")
.get()
.build();
client.newCall(request).enqueue(new Callback() {
- @Override public void onFailure(Call call, IOException e) {
+
+ @Override public void onFailure(Call call, final IOException e) {
+ runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+
+ Toast toast = Toast.makeText(getApplicationContext(),
+ "Request failed: " + e.toString(), Toast.LENGTH_LONG);
+
+ toast.setGravity(Gravity.CENTER,0,0);
+
+ toast.show();
+ }
+ });
e.printStackTrace();
}
- @Override public void onResponse(Call call, Response response) throws IOException {
- if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);
+ @Override public void onResponse(Call call, final Response response) throws IOException {
+
+ if (!response.isSuccessful()) {
+
+ runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+
+ Toast toast = Toast.makeText(getApplicationContext(),
+ "Response not successful with code " + response.code(), Toast.LENGTH_LONG);
+
+ toast.setGravity(Gravity.CENTER,0,0);
+
+ toast.show();
+ }
+ });
+
+ throw new IOException("Unexpected code " + response);
+ }
+
+ try { // Response successful
+
+ String jsonData = response.body().string();
+
+ JSONObject Jobject = new JSONObject(jsonData);
+
+ final String serverVersion = Jobject.get("version").toString();
+
+ runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+
+ Toast toast = Toast.makeText(getApplicationContext(),
+ "Server with version " + serverVersion + " detected", Toast.LENGTH_LONG);
+
+ toast.setGravity(Gravity.CENTER,0,0);
+
+ toast.show();
+ }
+ });
+
+ } catch (JSONException e) {
+ e.printStackTrace();
+ }
Headers responseHeaders = response.headers();
for (int i = 0, size = responseHeaders.size(); i < size; i++) {
System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i));
}
-
- System.out.println(response.body().string());
}
});
}
@@ -205,6 +277,7 @@ public class MainActivity extends Activity implements OnRemoteOperationListener,
}
@Override public void onResponse(Call call, Response response) throws IOException {
+
if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);
Headers responseHeaders = response.headers();