|
|
@ -39,22 +39,13 @@ import android.view.View; |
|
|
|
import android.widget.ImageView; |
|
|
|
import android.widget.ImageView; |
|
|
|
import android.widget.TextView; |
|
|
|
import android.widget.TextView; |
|
|
|
|
|
|
|
|
|
|
|
import com.android.volley.AuthFailureError; |
|
|
|
|
|
|
|
import com.android.volley.Request; |
|
|
|
|
|
|
|
import com.android.volley.Response; |
|
|
|
|
|
|
|
import com.android.volley.VolleyError; |
|
|
|
|
|
|
|
import com.android.volley.toolbox.JsonArrayRequest; |
|
|
|
|
|
|
|
import com.android.volley.toolbox.JsonObjectRequest; |
|
|
|
|
|
|
|
import com.keylesspalace.tusky.entity.Account; |
|
|
|
import com.keylesspalace.tusky.entity.Account; |
|
|
|
|
|
|
|
import com.keylesspalace.tusky.entity.Relationship; |
|
|
|
import com.pkmmte.view.CircularImageView; |
|
|
|
import com.pkmmte.view.CircularImageView; |
|
|
|
import com.squareup.picasso.Picasso; |
|
|
|
import com.squareup.picasso.Picasso; |
|
|
|
|
|
|
|
|
|
|
|
import org.json.JSONArray; |
|
|
|
import java.util.ArrayList; |
|
|
|
import org.json.JSONException; |
|
|
|
import java.util.List; |
|
|
|
import org.json.JSONObject; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.util.HashMap; |
|
|
|
|
|
|
|
import java.util.Map; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import retrofit2.Call; |
|
|
|
import retrofit2.Call; |
|
|
|
import retrofit2.Callback; |
|
|
|
import retrofit2.Callback; |
|
|
@ -247,40 +238,20 @@ public class AccountActivity extends BaseActivity { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void obtainRelationships() { |
|
|
|
private void obtainRelationships() { |
|
|
|
String endpoint = getString(R.string.endpoint_relationships); |
|
|
|
List<String> ids = new ArrayList<>(1); |
|
|
|
String url = String.format("https://%s%s?id=%s", domain, endpoint, accountId); |
|
|
|
ids.add(accountId); |
|
|
|
JsonArrayRequest request = new JsonArrayRequest(url, |
|
|
|
mastodonAPI.relationships(ids).enqueue(new Callback<List<Relationship>>() { |
|
|
|
new Response.Listener<JSONArray>() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onResponse(JSONArray response) { |
|
|
|
|
|
|
|
boolean following; |
|
|
|
|
|
|
|
boolean blocking; |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
JSONObject object = response.getJSONObject(0); |
|
|
|
|
|
|
|
following = object.getBoolean("following"); |
|
|
|
|
|
|
|
blocking = object.getBoolean("blocking"); |
|
|
|
|
|
|
|
} catch (JSONException e) { |
|
|
|
|
|
|
|
onObtainRelationshipsFailure(e); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
onObtainRelationshipsSuccess(following, blocking); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
new Response.ErrorListener() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onErrorResponse(VolleyError error) { |
|
|
|
|
|
|
|
onObtainRelationshipsFailure(error); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}) { |
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public Map<String, String> getHeaders() throws AuthFailureError { |
|
|
|
public void onResponse(Call<List<Relationship>> call, retrofit2.Response<List<Relationship>> response) { |
|
|
|
Map<String, String> headers = new HashMap<>(); |
|
|
|
Relationship relationship = response.body().get(0); |
|
|
|
headers.put("Authorization", "Bearer " + accessToken); |
|
|
|
onObtainRelationshipsSuccess(relationship.following, relationship.blocking); |
|
|
|
return headers; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
|
|
|
|
request.setTag(TAG); |
|
|
|
@Override |
|
|
|
VolleySingleton.getInstance(this).addToRequestQueue(request); |
|
|
|
public void onFailure(Call<List<Relationship>> call, Throwable t) { |
|
|
|
|
|
|
|
onObtainRelationshipsFailure((Exception) t); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void onObtainRelationshipsSuccess(boolean following, boolean blocking) { |
|
|
|
private void onObtainRelationshipsSuccess(boolean following, boolean blocking) { |
|
|
@ -347,50 +318,26 @@ public class AccountActivity extends BaseActivity { |
|
|
|
return super.onPrepareOptionsMenu(menu); |
|
|
|
return super.onPrepareOptionsMenu(menu); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void postRequest(String endpoint, Response.Listener<JSONObject> listener, |
|
|
|
private void follow(final String id) { |
|
|
|
Response.ErrorListener errorListener) { |
|
|
|
Callback<Relationship> cb = new Callback<Relationship>() { |
|
|
|
String url = "https://" + domain + endpoint; |
|
|
|
|
|
|
|
JsonObjectRequest request = new JsonObjectRequest(Request.Method.POST, url, null, listener, |
|
|
|
|
|
|
|
errorListener) { |
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public Map<String, String> getHeaders() throws AuthFailureError { |
|
|
|
public void onResponse(Call<Relationship> call, retrofit2.Response<Relationship> response) { |
|
|
|
Map<String, String> headers = new HashMap<>(); |
|
|
|
following = response.body().following; |
|
|
|
headers.put("Authorization", "Bearer " + accessToken); |
|
|
|
// TODO: display message/indicator when "requested" is true (i.e. when the follow is awaiting approval)
|
|
|
|
return headers; |
|
|
|
updateButtons(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onFailure(Call<Relationship> call, Throwable t) { |
|
|
|
|
|
|
|
onFollowFailure(id); |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
request.setTag(TAG); |
|
|
|
|
|
|
|
VolleySingleton.getInstance(this).addToRequestQueue(request); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void follow(final String id) { |
|
|
|
|
|
|
|
int endpointId; |
|
|
|
|
|
|
|
if (following) { |
|
|
|
if (following) { |
|
|
|
endpointId = R.string.endpoint_unfollow; |
|
|
|
mastodonAPI.unfollowAccount(id).enqueue(cb); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
endpointId = R.string.endpoint_follow; |
|
|
|
mastodonAPI.followAccount(id).enqueue(cb); |
|
|
|
} |
|
|
|
} |
|
|
|
postRequest(String.format(getString(endpointId), id), |
|
|
|
|
|
|
|
new Response.Listener<JSONObject>() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onResponse(JSONObject response) { |
|
|
|
|
|
|
|
boolean followingValue; |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
followingValue = response.getBoolean("following"); |
|
|
|
|
|
|
|
} catch (JSONException e) { |
|
|
|
|
|
|
|
onFollowFailure(id); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
following = followingValue; |
|
|
|
|
|
|
|
updateButtons(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
new Response.ErrorListener() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onErrorResponse(VolleyError error) { |
|
|
|
|
|
|
|
onFollowFailure(id); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void onFollowFailure(final String id) { |
|
|
|
private void onFollowFailure(final String id) { |
|
|
@ -412,33 +359,23 @@ public class AccountActivity extends BaseActivity { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void block(final String id) { |
|
|
|
private void block(final String id) { |
|
|
|
int endpointId; |
|
|
|
Callback<Relationship> cb = new Callback<Relationship>() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onResponse(Call<Relationship> call, retrofit2.Response<Relationship> response) { |
|
|
|
|
|
|
|
blocking = response.body().blocking; |
|
|
|
|
|
|
|
updateButtons(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onFailure(Call<Relationship> call, Throwable t) { |
|
|
|
|
|
|
|
onBlockFailure(id); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}; |
|
|
|
if (blocking) { |
|
|
|
if (blocking) { |
|
|
|
endpointId = R.string.endpoint_unblock; |
|
|
|
mastodonAPI.unblockAccount(id).enqueue(cb); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
endpointId = R.string.endpoint_block; |
|
|
|
mastodonAPI.blockAccount(id).enqueue(cb); |
|
|
|
} |
|
|
|
} |
|
|
|
postRequest(String.format(getString(endpointId), id), |
|
|
|
|
|
|
|
new Response.Listener<JSONObject>() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onResponse(JSONObject response) { |
|
|
|
|
|
|
|
boolean blockingValue; |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
blockingValue = response.getBoolean("blocking"); |
|
|
|
|
|
|
|
} catch (JSONException e) { |
|
|
|
|
|
|
|
onBlockFailure(id); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
blocking = blockingValue; |
|
|
|
|
|
|
|
updateButtons(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
new Response.ErrorListener() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void onErrorResponse(VolleyError error) { |
|
|
|
|
|
|
|
onBlockFailure(id); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void onBlockFailure(final String id) { |
|
|
|
private void onBlockFailure(final String id) { |
|
|
|