Add some internets!

WIP, not done yet.
This commit is contained in:
d8ahazard 2016-09-01 16:58:26 -05:00
parent 4f62320e7b
commit 0e23935455
6 changed files with 326 additions and 5 deletions

View File

@ -10,6 +10,7 @@ import android.widget.ImageView;
import android.widget.TextView; import android.widget.TextView;
import com.topjohnwu.magisk.module.Module; import com.topjohnwu.magisk.module.Module;
import com.topjohnwu.magisk.module.ModuleRepo;
import com.topjohnwu.magisk.utils.Shell; import com.topjohnwu.magisk.utils.Shell;
import com.topjohnwu.magisk.utils.Utils; import com.topjohnwu.magisk.utils.Utils;

View File

@ -12,6 +12,7 @@ import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager;
import android.util.Log;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.Menu; import android.view.Menu;
import android.view.MenuInflater; import android.view.MenuInflater;
@ -21,14 +22,12 @@ import android.view.ViewGroup;
import android.widget.ProgressBar; import android.widget.ProgressBar;
import com.topjohnwu.magisk.module.Module; import com.topjohnwu.magisk.module.Module;
import com.topjohnwu.magisk.utils.Shell; import com.topjohnwu.magisk.module.ModuleRepo;
import com.topjohnwu.magisk.utils.Utils; import com.topjohnwu.magisk.utils.Utils;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.concurrent.ExecutionException;
import butterknife.BindView; import butterknife.BindView;
import butterknife.ButterKnife; import butterknife.ButterKnife;
@ -37,6 +36,7 @@ public class ModulesFragment extends Fragment {
public static List<Module> listModules = new ArrayList<>(); public static List<Module> listModules = new ArrayList<>();
public static List<Module> listModulesCache = new ArrayList<>(); public static List<Module> listModulesCache = new ArrayList<>();
public static List<Module> listModulesDownload = new ArrayList<>();
private static final int FILE_SELECT_CODE = 0; private static final int FILE_SELECT_CODE = 0;
private File input; private File input;
@ -73,6 +73,7 @@ public class ModulesFragment extends Fragment {
}); });
} }
public void onActivityResult(int requestCode, int resultCode, Intent data) { public void onActivityResult(int requestCode, int resultCode, Intent data) {
@ -95,6 +96,7 @@ public class ModulesFragment extends Fragment {
case R.id.force_reload: case R.id.force_reload:
listModules.clear(); listModules.clear();
listModulesCache.clear(); listModulesCache.clear();
listModulesDownload.clear();
progressBar.setVisibility(View.VISIBLE); progressBar.setVisibility(View.VISIBLE);
viewPager.setAdapter(new TabsAdapter(getChildFragmentManager())); viewPager.setAdapter(new TabsAdapter(getChildFragmentManager()));
tabLayout.setupWithViewPager(viewPager); tabLayout.setupWithViewPager(viewPager);
@ -123,6 +125,15 @@ public class ModulesFragment extends Fragment {
} }
} }
public static class DownloadModuleFragment extends BaseModuleFragment {
@Override
protected List<Module> listModules() {
return listModulesDownload;
}
}
private class updateUI extends AsyncTask<Void, Void, Void> { private class updateUI extends AsyncTask<Void, Void, Void> {
@ -145,7 +156,7 @@ public class ModulesFragment extends Fragment {
private class TabsAdapter extends FragmentPagerAdapter { private class TabsAdapter extends FragmentPagerAdapter {
String[] tabTitles = new String[]{ String[] tabTitles = new String[]{
getString(R.string.modules), getString(R.string.cache_modules) getString(R.string.modules), getString(R.string.cache_modules) ,"Download"
}; };
public TabsAdapter(FragmentManager fm) { public TabsAdapter(FragmentManager fm) {
@ -166,9 +177,13 @@ public class ModulesFragment extends Fragment {
public Fragment getItem(int position) { public Fragment getItem(int position) {
if (position == 0) { if (position == 0) {
return new NormalModuleFragment(); return new NormalModuleFragment();
} else { } else if (position == 1) {
return new CacheModuleFragment(); return new CacheModuleFragment();
} else {
Log.d("Magisk","DL Fragment picked here");
return new DownloadModuleFragment();
} }
} }
} }
} }

View File

@ -74,6 +74,25 @@ public class Module {
} }
public Module(ModuleRepo.Repo repo) {
mName = repo.getName();
mVersion = repo.getVersion();
mDescription = repo.getDescription();
mId = "foo";
mVersionCode = 111;
mEnable = true;
mRemove = false;
}
public String getName() { public String getName() {
return mName; return mName;
} }

View File

@ -0,0 +1,170 @@
package com.topjohnwu.magisk.module;
import android.app.ListActivity;
import android.content.Context;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import com.topjohnwu.magisk.utils.WebRequest;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
public class ModuleRepo {
private String[] result;
private static String url = "https://api.github.com/orgs/Magisk-Modules-Repo/repos";
private static List<Repo> repos = new ArrayList<Repo>();
private static final String TAG_ID = "id";
private static final String TAG_NAME = "name";
private Context activityContext;
public List<Repo> listRepos() {
MyAsyncTask asynchTask = new MyAsyncTask();
Log.d("Magisk", "Gitagent init called");
asynchTask.execute();
List<String> out = null;
return repos;
}
public JSONArray fetchModuleArray() {
fetchRepoInfo();
parseRepoInfo();
JSONArray moduleArray = enumerateModules();
return null;
}
private void fetchRepoInfo() {
}
private void parseRepoInfo() {
}
private JSONArray enumerateModules() {
JSONArray enumeratedModules = new JSONArray();
return enumeratedModules;
}
class MyAsyncTask extends AsyncTask<String, String, Void> {
@Override
protected void onPreExecute() {
super.onPreExecute();
}
@Override
protected Void doInBackground(String... params) {
Log.d("Magisk", "doInBackground running");
// Creating service handler class instance
WebRequest webreq = new WebRequest();
// Making a request to url and getting response
String jsonStr = webreq.makeWebServiceCall(url, WebRequest.GET);
Log.d("Response: ", "> " + jsonStr);
try {
repos.clear();
JSONArray jsonArray = new JSONArray(jsonStr);
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonobject = jsonArray.getJSONObject(i);
String name = jsonobject.getString("name");
String urlString = jsonobject.getString("html_url");
try {
URL url = new URL(urlString);
if (!name.contains("Repo.github.io")) {
repos.add(new Repo(name, url));
}
} catch (MalformedURLException e) {
e.printStackTrace();
}
}
for (int i = 0; i < repos.size(); i++) {
Repo repo = repos.get(i);
Log.d("Magisk", repo.name + " URL: " + repo.url);
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
protected void onPostExecute(Void v) {
} // protected void onPostExecute(Void v)
} //class MyAsyncTask extends AsyncTask<String, String, Void>
protected void onPreExecute() {
}
public class Repo {
public String name;
public URL url;
public String manifest, version, moduleName, moduleDescription, moduleAuthor, moduleAuthorUrl;
public Boolean usesRoot,usesXposed;
public Repo(String name, URL url) {
this.name = name;
this.url = url;
this.manifest = ("https://raw.githubusercontent.com/Magisk-Modules-Repo/" + name + "/master/module.json");
WebRequest webreq = new WebRequest();
// Making a request to url and getting response
String manifestString = webreq.makeWebServiceCall(manifest, WebRequest.GET);
Log.d("Magisk","Inner fetch: " + manifestString);
try {
JSONObject jsonobject = new JSONObject(manifestString);
Log.d("Magisk","Object: " +jsonobject.toString());
version = jsonobject.getString("versionCode");
moduleName = jsonobject.getString("moduleName");
moduleDescription = jsonobject.getString("moduleDescription");
moduleAuthor = jsonobject.getString("moduleAuthor");
moduleAuthorUrl = jsonobject.getString("authorUrl");
usesRoot = Boolean.getBoolean(jsonobject.getString("usesRoot"));
usesXposed = Boolean.getBoolean(jsonobject.getString("usesXposed"));
} catch (JSONException e) {
e.printStackTrace();
}
Log.d("Magisk","We're in! " + " " + version + " " + moduleName + " " + moduleAuthor + " " + moduleDescription + " " + moduleAuthorUrl);
}
public String getName() {
return moduleName;
}
public String getVersion() {
return version;
}
public String getDescription() {
return moduleDescription;
}
}
}

View File

@ -16,12 +16,14 @@ import android.os.Environment;
import android.support.design.widget.Snackbar; import android.support.design.widget.Snackbar;
import android.support.v4.app.ActivityCompat; import android.support.v4.app.ActivityCompat;
import android.support.v7.app.AlertDialog; import android.support.v7.app.AlertDialog;
import android.util.Log;
import android.view.View; import android.view.View;
import android.widget.Toast; import android.widget.Toast;
import com.topjohnwu.magisk.ModulesFragment; import com.topjohnwu.magisk.ModulesFragment;
import com.topjohnwu.magisk.R; import com.topjohnwu.magisk.R;
import com.topjohnwu.magisk.module.Module; import com.topjohnwu.magisk.module.Module;
import com.topjohnwu.magisk.module.ModuleRepo;
import org.json.JSONException; import org.json.JSONException;
import org.json.JSONObject; import org.json.JSONObject;
@ -370,14 +372,23 @@ public class Utils {
protected Void doInBackground(Void... voids) { protected Void doInBackground(Void... voids) {
ModulesFragment.listModules.clear(); ModulesFragment.listModules.clear();
ModulesFragment.listModulesCache.clear(); ModulesFragment.listModulesCache.clear();
ModulesFragment.listModulesDownload.clear();
List<String> magisk = getModList(MAGISK_PATH); List<String> magisk = getModList(MAGISK_PATH);
Log.d("Magisk", String.valueOf(magisk));
List<String> magiskCache = getModList(MAGISK_CACHE_PATH); List<String> magiskCache = getModList(MAGISK_CACHE_PATH);
ModuleRepo mr = new ModuleRepo();
List<ModuleRepo.Repo> magiskRepos = mr.listRepos();
for (String mod : magisk) { for (String mod : magisk) {
Log.d("Magisk","Utils, listing modules " + mod);
ModulesFragment.listModules.add(new Module(mod)); ModulesFragment.listModules.add(new Module(mod));
} }
for (String mod : magiskCache) { for (String mod : magiskCache) {
ModulesFragment.listModulesCache.add(new Module(mod)); ModulesFragment.listModulesCache.add(new Module(mod));
} }
for (ModuleRepo.Repo repo : magiskRepos) {
ModulesFragment.listModulesDownload.add(new Module(repo));
}
return null; return null;
} }
} }

View File

@ -0,0 +1,105 @@
package com.topjohnwu.magisk.utils;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;
import javax.net.ssl.HttpsURLConnection;
public class WebRequest {
static String response = null;
public final static int GET = 1;
public final static int POST = 2;
//Constructor with no parameter
public WebRequest() {
}
/**
* Making web service call
*
* @url - url to make request
* @requestmethod - http request method
*/
public String makeWebServiceCall(String url, int requestmethod) {
return this.makeWebServiceCall(url, requestmethod, null);
}
/**
* Making service call
*
* @url - url to make request
* @requestmethod - http request method
* @params - http request params
*/
public String makeWebServiceCall(String urladdress, int requestmethod,
HashMap<String, String> params) {
URL url;
String response = "";
try {
url = new URL(urladdress);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setReadTimeout(15000);
conn.setConnectTimeout(15000);
conn.setDoInput(true);
if (requestmethod == POST) {
conn.setRequestMethod("POST");
} else if (requestmethod == GET) {
conn.setRequestMethod("GET");
}
if (params != null) {
OutputStream os = conn.getOutputStream();
BufferedWriter writer = new BufferedWriter(
new OutputStreamWriter(os, "UTF-8"));
StringBuilder result = new StringBuilder();
boolean first = true;
for (Map.Entry<String, String> entry : params.entrySet()) {
if (first)
first = false;
else
result.append("&");
result.append(URLEncoder.encode(entry.getKey(), "UTF-8"));
result.append("=");
result.append(URLEncoder.encode(entry.getValue(), "UTF-8"));
}
writer.write(result.toString());
writer.flush();
writer.close();
os.close();
}
int responseCode = conn.getResponseCode();
if (responseCode == HttpsURLConnection.HTTP_OK) {
String line;
BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
while ((line = br.readLine()) != null) {
response += line;
}
} else {
response = "";
}
} catch (Exception e) {
e.printStackTrace();
}
return response;
}
}