diff --git a/README.md b/README.md
index 68a670ba..dfc3a29b 100644
--- a/README.md
+++ b/README.md
@@ -49,6 +49,16 @@ Downloads
Changelog
---------
+Cambios en v1.129:
+* Fix cfi.
+* Agregado fr.ninemanga.
+* Opción para desabilitar el chequeo de certificados.
+
+Changes on v1.129:
+* Fix cfi.
+* Added fr.ninemanga.
+* Option to disable cert checks.
+
Cambios en v1.128:
* Pequeños arreglos.
diff --git a/app/build.gradle b/app/build.gradle
index f97ca19c..0ce45695 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -5,8 +5,8 @@ android {
buildToolsVersion '29.0.3'
defaultConfig {
applicationId "ar.rulosoft.mimanganu"
- versionCode 128
- versionName "1.128"
+ versionCode 129
+ versionName "1.129"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
minSdkVersion 15
}
@@ -39,6 +39,10 @@ android {
signingConfig signingConfigs.debug
}
}
+ compileOptions {
+ sourceCompatibility = 1.8
+ targetCompatibility = 1.8
+ }
compileOptions.encoding = 'UTF-8'
flavorDimensions "builds"
productFlavors {
@@ -83,7 +87,10 @@ dependencies {
implementation 'com.github.sevar83:indeterminate-checkbox:1.0.5@aar'
implementation group: 'org.brotli', name: 'dec', version: '0.1.2'
//implementation group: 'com.github.junrar', name: 'junrar', version: '4.0.0'
- implementation 'com.github.raulhaag:RapidDecoder:0.3.1Ax'
+ implementation 'rapid.decoder:library:0.3.0'
+ implementation 'rapid.decoder:jpeg-decoder:0.3.0'
+ implementation 'rapid.decoder:png-decoder:0.3.0'
+ //implementation 'com.github.raulhaag:RapidDecoder:0.3.1Ax'
implementation 'com.squareup.okhttp3:okhttp:3.9.1' //on 3.10.0 are deprecated some ciphers
implementation 'com.squareup.okio:okio:1.15.0'
implementation 'com.squareup.duktape:duktape-android:1.2.0'/* v 1.2.0 need 4+mb extra*/
diff --git a/app/src/androidTest/java/ar/rulosoft/mimanganu/testNine.java b/app/src/androidTest/java/ar/rulosoft/mimanganu/testNine.java
index 9e6a5867..f739e983 100644
--- a/app/src/androidTest/java/ar/rulosoft/mimanganu/testNine.java
+++ b/app/src/androidTest/java/ar/rulosoft/mimanganu/testNine.java
@@ -1,7 +1,6 @@
package ar.rulosoft.mimanganu;
import android.content.Context;
-import android.util.Log;
import androidx.test.filters.LargeTest;
import androidx.test.rule.ActivityTestRule;
@@ -13,10 +12,17 @@
import ar.rulosoft.mimanganu.componentes.Chapter;
import ar.rulosoft.mimanganu.componentes.Manga;
+import ar.rulosoft.mimanganu.servers.JSServerHelper;
+import ar.rulosoft.mimanganu.servers.TuMangaOnline;
+import ar.rulosoft.mimanganu.utils.Util;
import ar.rulosoft.navegadores.Navigator;
import okhttp3.Request;
import okio.Buffer;
+import static ar.rulosoft.mimanganu.servers.ServerBase.TUMANGAONLINE;
+import static ar.rulosoft.mimanganu.servers.ServerBase.getFirstMatch;
+import static ar.rulosoft.mimanganu.servers.ServerBase.getServer;
+
/**
* Created by Raul on 01/04/2017.
*/
@@ -28,6 +34,10 @@ public class testNine {
private Context context;
private Manga manga;
private Chapter chapter;
+ private String script;
+ private TuMangaOnline tmoServ = (TuMangaOnline) getServer(TUMANGAONLINE, context);
+ private JSServerHelper scriptHelper;
+
private static String bodyToString(final Request request){
try {
@@ -43,19 +53,22 @@ private static String bodyToString(final Request request){
@Test
public void testImages() throws Exception {
Navigator nav = Navigator.getInstance();
- nav.addHeader("Accept-Language", "es-AR,es;q=0.8,en-US;q=0.5,en;q=0.3");
- nav.addHeader("Accept-Encoding", "deflate");
- nav.addHeader("Accept","application/json, text/plain, */*");
- nav.addHeader("Accept-Encoding","gzip, deflate, br");
- nav.addHeader("Accept-Language","es-AR,es;q=0.8,en-US;q=0.5,en;q=0.3");
- nav.addHeader("Cache-mode","no-cache");
- //nav.addHeader("Connection","keep-alive");
- nav.addHeader("Cookie","__cfduid=d7025d17b59e189d890c2cc05b9feb5c31505483555; tmoSession=eyJpdiI6ImZXZUlPZjVWOGNKS2VCRkVcL1I3XC9iZz09IiwidmFsdWUiOiJ0MEhzdXF0XC93YkFvSkJlUnVvZ3hnN011WWtGUzdEdnJrY1ZOakhnTVRBTGJQZk91NmphTTFaNDhhbUozUnZnRmJndGtBdkNHZlFsTTFZT2RvSWlBSGc9PSIsIm1hYyI6ImMxODZmYmRkNTJiZTQ4YjUwZGQ0MTBkYTRlOWExNmU1NjM3YWFkMTA2MGJjNGJhMzMwOGY3NjY0YmFhMDIyMmIifQ%3D%3D");
- //nav.addHeader("Host","www.tumangaonline.com");
- nav.addHeader("Referer","https://www.tumangaonline.com/biblioteca");
- //nav.addHeader("User-Agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:54.0) Gecko/20100101 Firefox/54.0");
- //nav.addHeader("X-Requested-With","XMLHttpRequest");
- Log.e("respuesta", nav.get("https://www.tumangaonline.com/api/v1/mangas/2968/capitulos?page=2&tomo=-1"));
+ checkScript();
+ scriptHelper.notifyAll();
+ }
+
+ private void checkScript() throws Exception {
+ if (scriptHelper == null) {
+ String d = " " + context.getString(R.string.factor_suffix).hashCode() + getServer(TUMANGAONLINE, context).getServerID() + TUMANGAONLINE;
+ try {
+ script = Util.xorDecode(tmoServ.getNavWithNeededHeaders().get("https://raw.githubusercontent.com/raulhaag/MiMangaNu/master/js_plugin/" + tmoServ.getServerID() + "_5.js"), d);
+ } catch (Exception e) {
+ script = tmoServ.getNavWithNeededHeaders().get("https://github.com/raulhaag/MiMangaNu/blob/master/js_plugin/" + tmoServ.getServerID() + "_5.js");
+ script = Util.xorDecode(Util.getInstance().fromHtml(getFirstMatch("(
)", script, "error obteniendo script")).toString(), d);
+ }
+ if (!script.isEmpty())
+ scriptHelper = new JSServerHelper(context, script);
+ }
}
diff --git a/app/src/main/java/ar/rulosoft/mimanganu/servers/TuMangaOnline.java b/app/src/main/java/ar/rulosoft/mimanganu/servers/TuMangaOnline.java
index df8c4879..7f110fb2 100644
--- a/app/src/main/java/ar/rulosoft/mimanganu/servers/TuMangaOnline.java
+++ b/app/src/main/java/ar/rulosoft/mimanganu/servers/TuMangaOnline.java
@@ -16,11 +16,11 @@
/**
* Created by Raul on 05/04/2016.
*/
-class TuMangaOnline extends ServerBase {
+public class TuMangaOnline extends ServerBase {
private static final String HOST = "https://tmofans.com";
public static String script = null;
- private JSServerHelper scriptHelper;
+ public JSServerHelper scriptHelper;
public static String[] type = new String[]{
"Todos", "Manga", "Manhua", "Manhwa", "Novela", "One Shot", "Dounjinshi", "Oel"
@@ -160,7 +160,7 @@ public ArrayList getMangasFiltered(int[][] filters, int pageNumber) throw
return scriptHelper.getMangasFiltered(filters, pageNumber);
}
- private Navigator getNavWithNeededHeaders() {
+ public Navigator getNavWithNeededHeaders() {
Navigator nav = getNavigatorAndFlushParameters();
nav.addHeader("Cache-mode", "no-cache");
nav.addHeader("Referer", HOST + "/library/manga/");
diff --git a/app/src/main/java/ar/rulosoft/mimanganu/services/SingleDownload.java b/app/src/main/java/ar/rulosoft/mimanganu/services/SingleDownload.java
index 2065ec87..765bf00d 100644
--- a/app/src/main/java/ar/rulosoft/mimanganu/services/SingleDownload.java
+++ b/app/src/main/java/ar/rulosoft/mimanganu/services/SingleDownload.java
@@ -11,6 +11,9 @@
import java.io.OutputStream;
import java.util.concurrent.TimeUnit;
+import javax.net.ssl.HostnameVerifier;
+import javax.net.ssl.SSLSession;
+
import ar.rulosoft.mimanganu.utils.PostProcess;
import ar.rulosoft.navegadores.Navigator;
import okhttp3.OkHttpClient;
@@ -84,9 +87,16 @@ public void run() {
copy = Navigator.getInstance().getHttpClient().newBuilder()
.connectTimeout(5, TimeUnit.SECONDS)
.readTimeout(20, TimeUnit.SECONDS)
+ .hostnameVerifier(new HostnameVerifier() {
+ @Override
+ public boolean verify(String hostname, SSLSession session) {
+ return true;
+ }
+ })
.build();
rBuilder = new Request.Builder()
- .addHeader("User-Agent", Navigator.USER_AGENT);
+ .addHeader("User-Agent", Navigator.USER_AGENT)
+ .addHeader("Connection", "keep-alive");
if (referer) {
if (inRef != null) {
rBuilder.addHeader("Referer", inRef);
@@ -103,9 +113,8 @@ public void run() {
changeStatus(Status.ERROR_CONNECTION);
}
retry = 0;
- if (!ot.delete()) {
- Log.e("SingleDownload", "failed to delete temporary file");
- }
+ //noinspection ResultOfMethodCallIgnored
+ ot.delete();
writeErrorImage(ot);
if (!ot.renameTo(o)) {
Log.e("SingleDownload", "failed to rename temporary file");
diff --git a/app/src/main/java/ar/rulosoft/navegadores/CFInterceptor.java b/app/src/main/java/ar/rulosoft/navegadores/CFInterceptor.java
index 77c7b0b9..4106de09 100644
--- a/app/src/main/java/ar/rulosoft/navegadores/CFInterceptor.java
+++ b/app/src/main/java/ar/rulosoft/navegadores/CFInterceptor.java
@@ -28,8 +28,6 @@
public class CFInterceptor implements Interceptor {
private final static Pattern OPERATION_PATTERN = Pattern.compile("setTimeout\\(function\\(\\)\\{\\s+(var .,.,.,.[\\s\\S]+?a\\.value = .+?;)", Pattern.DOTALL);
- private final static Pattern PASS_PATTERN = Pattern.compile("name=\"pass\" value=\"(.+?)\"", Pattern.DOTALL);
- private final static Pattern CHALLENGE_PATTERN = Pattern.compile("name=\"jschl_vc\" value=\"(\\w+)\"", Pattern.DOTALL);
private final static Pattern EXTRA_STRING_ADDED_PATTERN = Pattern.compile("([^<]+)<");
private final static Pattern FORM_ACTION = Pattern.compile("action=\"([^\"]+)");
@@ -52,7 +50,7 @@ public Response intercept(Chain chain) throws IOException {
return response;
}
- public Response resolveOverCF(Chain chain, Response response) throws IOException {
+ public synchronized Response resolveOverCF(Chain chain, Response response) throws IOException {
Request request = response.request();
String domain = request.url().host().trim();
String content = response.body().string();
diff --git a/app/src/main/java/ar/rulosoft/navegadores/Navigator.java b/app/src/main/java/ar/rulosoft/navegadores/Navigator.java
index 6f1c34b1..63cc23fb 100644
--- a/app/src/main/java/ar/rulosoft/navegadores/Navigator.java
+++ b/app/src/main/java/ar/rulosoft/navegadores/Navigator.java
@@ -29,7 +29,9 @@
import java.util.regex.Matcher;
import java.util.regex.Pattern;
+import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.SSLContext;
+import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;
@@ -55,6 +57,7 @@ public class Navigator {
public static int writeTimeout = 10;
public static int readTimeout = 30;
public static int connectionRetry = 10;
+ private static boolean trustAll;
private static CookieJar cookieJar;
private static Navigator instance;
public OkHttpClient httpClient;
@@ -74,6 +77,7 @@ private Navigator(Context context) throws Exception {
connectionRetry = Integer.parseInt(prefs.getString("connection_retry", "10"));
readTimeout = Integer.parseInt(prefs.getString("read_timeout", "30"));
connectionTimeout = Integer.parseInt(prefs.getString("connection_timeout", "10"));
+ trustAll = prefs.getBoolean("accept_all_certs", false);
cookieJar = new CookieFilter(new SetCookieCache(), new SharedPrefsCookiePersistor(context));
initClient(cookieJar, context);
}
@@ -110,7 +114,28 @@ public static CookieJar getCookieJar() {
}
private void initClient(CookieJar cookieJar, Context context) throws KeyManagementException, NoSuchAlgorithmException {
- TrustManager[] trustManagers = getTrustManagers(context);
+ TrustManager[] trustManagers;
+ if (trustAll) {
+ trustManagers = new TrustManager[]{
+ new X509TrustManager() {
+ @Override
+ public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
+ }
+
+ @Override
+ public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
+ }
+
+ @Override
+ public java.security.cert.X509Certificate[] getAcceptedIssuers() {
+ return new java.security.cert.X509Certificate[]{};
+ }
+ }
+ };
+ } else {
+ trustManagers = getTrustManagers(context);
+ }
+
SSLContext sslContext = SSLContext.getInstance("TLS");
sslContext.init(null, trustManagers, null);
SSLSocketFactory socketFactory = null;
@@ -119,7 +144,8 @@ private void initClient(CookieJar cookieJar, Context context) throws KeyManageme
} else {
socketFactory = sslContext.getSocketFactory();
}
- httpClient = new OkHttpClientConnectionChecker.Builder()
+
+ OkHttpClientConnectionChecker.Builder cBuilder = new OkHttpClientConnectionChecker.Builder()
.addInterceptor(new UncompressInterceptor())
.addInterceptor(new RetryInterceptor())// the interceptors list appear to be a lifo
.addInterceptor(new CFInterceptor())
@@ -129,7 +155,16 @@ private void initClient(CookieJar cookieJar, Context context) throws KeyManageme
.readTimeout(30, TimeUnit.SECONDS)
.cookieJar(cookieJar)
//.dns(new MmNDNS())//
- .build();
+ ;
+ if (trustAll) {
+ cBuilder.hostnameVerifier(new HostnameVerifier() {
+ @Override
+ public boolean verify(String hostname, SSLSession session) {
+ return true;
+ }
+ });
+ }
+ httpClient = cBuilder.build();
Navigator.cookieJar = cookieJar;
}
diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml
index 7b40b532..8c02fdac 100644
--- a/app/src/main/res/values-es/strings.xml
+++ b/app/src/main/res/values-es/strings.xml
@@ -1,6 +1,7 @@
- Cambios en v1.128:\n\t* Pequeños arreglos.
+ Cambios en v1.129:\n\t* Fix cfi.\n\t* Agregado fr.ninemanga.\n\t* Opción para desabilitar el chequeo de certificados.
+
Ajustar a
Descargas
Datos de
@@ -466,5 +467,17 @@
Tu dispositivo no soporta esta función.
Reiniciar aplicación
Contactar al desarrollador
+ Si estas necesitando espacio
+ Borrar la imagenes de todos los mangas
+ Borrando imagenes, espera hasta el próximo mensaje.
+ Preceso terminado.
+ ¿Estas seguro?
+ Deshabilitar el chequeo de certificados
+ Si tienes una vesion vieja de android o un servidor tiene problemas.
+ Backup no encotrado
+ Correr test de servidores
+ Test basico sobre servidores.
+ Nuevos mangas y actualizaciones.
+ Buqueda de nuevos capítulos.
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index c9c9929c..b512103e 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -1,6 +1,6 @@
- Changes on v1.128:\n\t* Small Fixes.
+ Changes on v1.129:\n\t* Fix cfi.\n\t* Added fr.ninemanga.\n\t* Option to disable cert checks.
12 Hours
1 day
2 days
@@ -514,5 +514,7 @@
Deleting all images please wait until next message.
Process finished.
Are you sure?
+ Disable cert check
+ If you have old android and/or the server cert are\'t trusted (need restart)
diff --git a/app/src/main/res/xml/fragment_preferences.xml b/app/src/main/res/xml/fragment_preferences.xml
index 68fd32aa..c95fa479 100644
--- a/app/src/main/res/xml/fragment_preferences.xml
+++ b/app/src/main/res/xml/fragment_preferences.xml
@@ -34,6 +34,11 @@
android:key="only_wifi"
android:summary="@string/use_only_wifi_subtitle"
android:title="@string/use_only_wifi_title" />
+