Start work on integrating Retrofit - GSON, Authorization
This commit is contained in:
parent
cff0f35269
commit
348d2c8b4f
6 changed files with 74 additions and 112 deletions
|
@ -36,4 +36,5 @@ dependencies {
|
||||||
testCompile 'junit:junit:4.12'
|
testCompile 'junit:junit:4.12'
|
||||||
compile 'com.mikhaellopez:circularfillableloaders:1.2.0'
|
compile 'com.mikhaellopez:circularfillableloaders:1.2.0'
|
||||||
compile 'com.squareup.retrofit2:retrofit:2.2.0'
|
compile 'com.squareup.retrofit2:retrofit:2.2.0'
|
||||||
|
compile 'com.squareup.retrofit2:converter-gson:2.1.0'
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,9 @@
|
||||||
|
|
||||||
package com.keylesspalace.tusky;
|
package com.keylesspalace.tusky;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
import android.graphics.PorterDuff;
|
import android.graphics.PorterDuff;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
|
@ -26,11 +28,22 @@ import android.support.v7.app.AppCompatActivity;
|
||||||
import android.util.TypedValue;
|
import android.util.TypedValue;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import okhttp3.Interceptor;
|
||||||
|
import okhttp3.OkHttpClient;
|
||||||
|
import okhttp3.Request;
|
||||||
|
import okhttp3.Response;
|
||||||
|
import retrofit2.Retrofit;
|
||||||
|
import retrofit2.converter.gson.GsonConverterFactory;
|
||||||
|
|
||||||
/* There isn't presently a way to globally change the theme of a whole application at runtime, just
|
/* There isn't presently a way to globally change the theme of a whole application at runtime, just
|
||||||
* individual activities. So, each activity has to set its theme before any views are created. And
|
* individual activities. So, each activity has to set its theme before any views are created. And
|
||||||
* the most expedient way to accomplish this was to put it in a base class and just have every
|
* the most expedient way to accomplish this was to put it in a base class and just have every
|
||||||
* activity extend from it. */
|
* activity extend from it. */
|
||||||
public class BaseActivity extends AppCompatActivity {
|
public class BaseActivity extends AppCompatActivity {
|
||||||
|
protected MastodonAPI mastodonAPI;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
@ -59,6 +72,42 @@ public class BaseActivity extends AppCompatActivity {
|
||||||
overridePendingTransition(R.anim.slide_from_left, R.anim.slide_to_right);
|
overridePendingTransition(R.anim.slide_from_left, R.anim.slide_to_right);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected String getAccessToken() {
|
||||||
|
SharedPreferences preferences = getSharedPreferences(getString(R.string.preferences_file_key), Context.MODE_PRIVATE);
|
||||||
|
return preferences.getString("accessToken", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected String getBaseUrl() {
|
||||||
|
SharedPreferences preferences = getSharedPreferences(getString(R.string.preferences_file_key), Context.MODE_PRIVATE);
|
||||||
|
return "https://" + preferences.getString("domain", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void createMastodonAPI() {
|
||||||
|
OkHttpClient okHttpClient = new OkHttpClient.Builder()
|
||||||
|
.addInterceptor(new Interceptor() {
|
||||||
|
@Override
|
||||||
|
public Response intercept(Chain chain) throws IOException {
|
||||||
|
Request originalRequest = chain.request();
|
||||||
|
|
||||||
|
Request.Builder builder = originalRequest.newBuilder()
|
||||||
|
.header("Authorization", String.format("Bearer %s", getAccessToken()));
|
||||||
|
|
||||||
|
Request newRequest = builder.build();
|
||||||
|
|
||||||
|
return chain.proceed(newRequest);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Retrofit retrofit = new Retrofit.Builder()
|
||||||
|
.baseUrl(getBaseUrl())
|
||||||
|
.client(okHttpClient)
|
||||||
|
.addConverterFactory(GsonConverterFactory.create())
|
||||||
|
.build();
|
||||||
|
|
||||||
|
mastodonAPI = retrofit.create(MastodonAPI.class);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
TypedValue value = new TypedValue();
|
TypedValue value = new TypedValue();
|
||||||
|
|
|
@ -7,6 +7,7 @@ import com.keylesspalace.tusky.entity.StatusContext;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import okhttp3.RequestBody;
|
import okhttp3.RequestBody;
|
||||||
|
import okhttp3.ResponseBody;
|
||||||
import retrofit2.Call;
|
import retrofit2.Call;
|
||||||
import retrofit2.http.DELETE;
|
import retrofit2.http.DELETE;
|
||||||
import retrofit2.http.Field;
|
import retrofit2.http.Field;
|
||||||
|
@ -18,7 +19,7 @@ import retrofit2.http.Part;
|
||||||
import retrofit2.http.Path;
|
import retrofit2.http.Path;
|
||||||
import retrofit2.http.Query;
|
import retrofit2.http.Query;
|
||||||
|
|
||||||
public interface MastodonService {
|
public interface MastodonAPI {
|
||||||
@GET("api/v1/timelines/home")
|
@GET("api/v1/timelines/home")
|
||||||
Call<List<Status>> homeTimeline(@Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
Call<List<Status>> homeTimeline(@Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
||||||
@GET("api/v1/timelines/public")
|
@GET("api/v1/timelines/public")
|
||||||
|
@ -29,7 +30,7 @@ public interface MastodonService {
|
||||||
@GET("api/v1/notifications")
|
@GET("api/v1/notifications")
|
||||||
Call<List<Notification>> notifications(@Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
Call<List<Notification>> notifications(@Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
||||||
@POST("api/v1/notifications/clear")
|
@POST("api/v1/notifications/clear")
|
||||||
Call clearNotifications();
|
Call<ResponseBody> clearNotifications();
|
||||||
@GET("api/v1/notifications/{id}")
|
@GET("api/v1/notifications/{id}")
|
||||||
Call<Notification> notification(@Path("id") int notificationId);
|
Call<Notification> notification(@Path("id") int notificationId);
|
||||||
|
|
||||||
|
@ -49,7 +50,7 @@ public interface MastodonService {
|
||||||
@GET("api/v1/statuses/{id}/favourited_by")
|
@GET("api/v1/statuses/{id}/favourited_by")
|
||||||
Call<List<Account>> statusFavouritedBy(@Path("id") int statusId, @Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
Call<List<Account>> statusFavouritedBy(@Path("id") int statusId, @Query("max_id") int maxId, @Query("since_id") int sinceId, @Query("limit") int limit);
|
||||||
@DELETE("api/v1/statuses/{id}")
|
@DELETE("api/v1/statuses/{id}")
|
||||||
Call deleteStatus(@Path("id") int statusId);
|
Call<ResponseBody> deleteStatus(@Path("id") int statusId);
|
||||||
@POST("api/v1/statuses/{id}/reblog")
|
@POST("api/v1/statuses/{id}/reblog")
|
||||||
Call<Status> reblogStatus(@Path("id") int statusId);
|
Call<Status> reblogStatus(@Path("id") int statusId);
|
||||||
@POST("api/v1/statuses/{id}/unreblog")
|
@POST("api/v1/statuses/{id}/unreblog")
|
|
@ -1,49 +1,17 @@
|
||||||
package com.keylesspalace.tusky.entity;
|
package com.keylesspalace.tusky.entity;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
public class Media {
|
public class Media {
|
||||||
int id;
|
public int id;
|
||||||
String type;
|
|
||||||
String url;
|
|
||||||
String preview_url;
|
|
||||||
String text_url;
|
|
||||||
|
|
||||||
public int getId() {
|
public String type;
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(int id) {
|
public String url;
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getType() {
|
@SerializedName("preview_url")
|
||||||
return type;
|
public String previewUrl;
|
||||||
}
|
|
||||||
|
|
||||||
public void setType(String type) {
|
@SerializedName("text_url")
|
||||||
this.type = type;
|
public String textUrl;
|
||||||
}
|
|
||||||
|
|
||||||
public String getUrl() {
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUrl(String url) {
|
|
||||||
this.url = url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getPreview_url() {
|
|
||||||
return preview_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPreview_url(String preview_url) {
|
|
||||||
this.preview_url = preview_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getText_url() {
|
|
||||||
return text_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setText_url(String text_url) {
|
|
||||||
this.text_url = text_url;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,58 +1,18 @@
|
||||||
package com.keylesspalace.tusky.entity;
|
package com.keylesspalace.tusky.entity;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
public class Relationship {
|
public class Relationship {
|
||||||
public boolean isFollowing() {
|
public int id;
|
||||||
return following;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFollowing(boolean following) {
|
public boolean following;
|
||||||
this.following = following;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isFollowed_by() {
|
@SerializedName("followed_by")
|
||||||
return followed_by;
|
public boolean followedBy;
|
||||||
}
|
|
||||||
|
|
||||||
public void setFollowed_by(boolean followed_by) {
|
public boolean blocking;
|
||||||
this.followed_by = followed_by;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isBlocking() {
|
public boolean muting;
|
||||||
return blocking;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setBlocking(boolean blocking) {
|
public boolean requested;
|
||||||
this.blocking = blocking;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isMuting() {
|
|
||||||
return muting;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setMuting(boolean muting) {
|
|
||||||
this.muting = muting;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isRequested() {
|
|
||||||
return requested;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setRequested(boolean requested) {
|
|
||||||
this.requested = requested;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(int id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
int id;
|
|
||||||
boolean following;
|
|
||||||
boolean followed_by;
|
|
||||||
boolean blocking;
|
|
||||||
boolean muting;
|
|
||||||
boolean requested;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,23 +5,6 @@ import com.keylesspalace.tusky.Status;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class StatusContext {
|
public class StatusContext {
|
||||||
List<Status> ancestors;
|
public List<Status> ancestors;
|
||||||
|
public List<Status> descendants;
|
||||||
public List<Status> getAncestors() {
|
|
||||||
return ancestors;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setAncestors(List<Status> ancestors) {
|
|
||||||
this.ancestors = ancestors;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Status> getDescendants() {
|
|
||||||
return descendants;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDescendants(List<Status> descendants) {
|
|
||||||
this.descendants = descendants;
|
|
||||||
}
|
|
||||||
|
|
||||||
List<Status> descendants;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue