GitNex-Android-App/app/src/main/java/org/mian/gitnex/clients/RetrofitClient.java

84 lines
3.1 KiB
Java
Raw Normal View History

package org.mian.gitnex.clients;
2019-11-13 16:52:49 +01:00
import android.content.Context;
2020-03-31 16:41:50 +02:00
import android.util.Log;
import org.mian.gitnex.interfaces.ApiInterface;
2020-03-31 16:44:11 +02:00
import org.mian.gitnex.helpers.MemorizingTrustManager;
2019-11-13 16:52:49 +01:00
import org.mian.gitnex.util.AppUtil;
import java.io.File;
import java.security.SecureRandom;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.X509TrustManager;
2019-11-13 16:52:49 +01:00
import okhttp3.Cache;
import okhttp3.OkHttpClient;
2019-11-13 16:52:49 +01:00
import okhttp3.Request;
import okhttp3.logging.HttpLoggingInterceptor;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;
import retrofit2.converter.scalars.ScalarsConverterFactory;
/**
* Author M M Arif
*/
public class RetrofitClient {
private Retrofit retrofit;
2020-03-31 16:41:50 +02:00
private RetrofitClient(String instanceUrl, Context ctx) {
final boolean connToInternet = AppUtil.haveNetworkConnection(ctx);
2019-11-24 13:42:57 +01:00
int cacheSize = 50 * 1024 * 1024; // 50MB
2020-03-31 16:41:50 +02:00
File httpCacheDirectory = new File(ctx.getCacheDir(), "responses");
2019-11-13 16:52:49 +01:00
Cache cache = new Cache(httpCacheDirectory, cacheSize);
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
logging.setLevel(HttpLoggingInterceptor.Level.BODY);
try {
SSLContext sslContext = SSLContext.getInstance("TLS");
2020-03-31 16:41:50 +02:00
MemorizingTrustManager memorizingTrustManager = new MemorizingTrustManager(ctx);
sslContext.init(null, new X509TrustManager[] { memorizingTrustManager }, new SecureRandom());
OkHttpClient.Builder okHttpClient = new OkHttpClient.Builder()
.cache(cache)
2020-03-31 16:41:50 +02:00
//.addInterceptor(logging)
.sslSocketFactory(sslContext.getSocketFactory(), memorizingTrustManager)
.hostnameVerifier(memorizingTrustManager.wrapHostnameVerifier(HttpsURLConnection.getDefaultHostnameVerifier()))
.addInterceptor(chain -> {
2020-03-31 16:41:50 +02:00
Request request = chain.request();
if(connToInternet) {
request = request.newBuilder().header("Cache-Control", "public, max-age=" + 60).build();
}
else {
request = request.newBuilder().header("Cache-Control", "public, only-if-cached, max-stale=" + 60 * 60 * 24 * 30).build();
}
2019-11-13 16:52:49 +01:00
return chain.proceed(request);
});
Retrofit.Builder builder = new Retrofit.Builder()
.baseUrl(instanceUrl)
.client(okHttpClient.build())
.addConverterFactory(ScalarsConverterFactory.create())
.addConverterFactory(GsonConverterFactory.create());
2019-11-13 16:52:49 +01:00
retrofit = builder.build();
2020-03-31 16:41:50 +02:00
}
catch(Exception e) {
Log.e("onFailure", e.toString());
}
}
2019-11-13 16:52:49 +01:00
public static synchronized RetrofitClient getInstance(String instanceUrl, Context ctx) {
return new RetrofitClient(instanceUrl, ctx);
}
public ApiInterface getApiInterface() {
return retrofit.create(ApiInterface.class);
}
}