refactor(main): 重构MainActivity并引入国家代码切换功能
- 重构了 MainActivity 的 onCreate 方法,将初始化逻辑拆分为多个独立方法,包括组件初始化、权限检查、网络检查和 WorkManager 设置。 - 引入了国家代码切换功能,允许在 "us" 和 "ru" 之间切换,并在启动 VPN 和获取设备信息时使用当前选择的国家代码。 - 优化了按钮初始化逻辑,使用 `setupButton` 方法统一处理按钮的查找和点击事件设置。 - 将部分硬编码字符串提取到 `strings.xml` 中。 - 移除了 ChangeDeviceInfoUtil 中的 `initialize` 方法,其功能已整合到 `getAddDeviceInfo` 中。 - 在执行主要任务逻辑 `executeLogic` 中,根据当前选择的国家代码来获取设备信息。 - 调整了部分日志记录的 TAG。 - 移除了 `getInstance` 方法,不再提供 MainActivity 的静态实例获取。
This commit is contained in:
parent
f41f54c572
commit
069348cb43
|
@ -11,16 +11,20 @@ import android.net.ConnectivityManager;
|
||||||
import android.net.Network;
|
import android.net.Network;
|
||||||
import android.net.NetworkCapabilities;
|
import android.net.NetworkCapabilities;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
|
import android.os.Build.VERSION;
|
||||||
|
import android.os.Build.VERSION_CODES;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
import android.Manifest;
|
import android.Manifest;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
|
|
||||||
|
import androidx.annotation.IdRes;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.core.app.ActivityCompat;
|
import androidx.core.app.ActivityCompat;
|
||||||
import androidx.core.content.ContextCompat;
|
import androidx.core.content.ContextCompat;
|
||||||
|
@ -39,12 +43,14 @@ import com.example.studyapp.utils.IpUtil;
|
||||||
import com.example.studyapp.utils.LogFileUtil;
|
import com.example.studyapp.utils.LogFileUtil;
|
||||||
import com.example.studyapp.worker.CheckAccessibilityWorker;
|
import com.example.studyapp.worker.CheckAccessibilityWorker;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.ExecutorService;
|
import java.util.concurrent.ExecutorService;
|
||||||
import java.util.concurrent.LinkedBlockingQueue;
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
import java.util.concurrent.ThreadPoolExecutor;
|
import java.util.concurrent.ThreadPoolExecutor;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
public class MainActivity extends AppCompatActivity {
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
|
@ -95,133 +101,160 @@ public class MainActivity extends AppCompatActivity {
|
||||||
* @return 设备的 ANDROID_ID,若无法获取,则返回 null
|
* @return 设备的 ANDROID_ID,若无法获取,则返回 null
|
||||||
*/
|
*/
|
||||||
private String getAndroidId(Context context) {
|
private String getAndroidId(Context context) {
|
||||||
// if (context == null) {
|
|
||||||
// LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "getAndroidId: Context cannot be null",null);
|
|
||||||
// throw new IllegalArgumentException("Context cannot be null");
|
|
||||||
// }
|
|
||||||
// try {
|
|
||||||
// return Settings.Secure.getString(
|
|
||||||
// context.getContentResolver(),
|
|
||||||
// Settings.Secure.ANDROID_ID
|
|
||||||
// );
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "getAndroidId: Failed to get ANDROID_ID",e);
|
|
||||||
// return null;
|
|
||||||
// }
|
|
||||||
return "FyZqWrStUvOpKlMn";
|
return "FyZqWrStUvOpKlMn";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private static final int REQUEST_CODE_PERMISSIONS = 100;
|
private static final int REQUEST_CODE_PERMISSIONS = 100;
|
||||||
|
|
||||||
|
private static final String TAG = "MainActivity";
|
||||||
|
private static final String PACKAGE_SCHEME = "package:";
|
||||||
|
private static final String COUNTRY_CODE = "US";
|
||||||
|
private static final int DEVICE_TYPE = 2;
|
||||||
|
|
||||||
|
// 定义支持的国家代码常量
|
||||||
|
private static final class CountryCode {
|
||||||
|
|
||||||
|
static final String US = "us";
|
||||||
|
static final String RU = "ru";
|
||||||
|
// 默认使用美国
|
||||||
|
static final String DEFAULT = US;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 当前使用的国家代码
|
||||||
|
private String currentCountry = CountryCode.DEFAULT;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
initializeBasicComponents();
|
||||||
|
checkAndRequestPermissions();
|
||||||
|
checkNetworkConnection();
|
||||||
|
setupWorkManager();
|
||||||
|
initializeButtons();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializeBasicComponents() {
|
||||||
LogFileUtil.initialize(this);
|
LogFileUtil.initialize(this);
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
instance = new WeakReference<>(this);
|
instance = new WeakReference<>(this);
|
||||||
|
LogFileUtil.logAndWrite(Log.INFO, TAG, "onCreate: Initializing application", null);
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "onCreate: Initializing application", null);
|
|
||||||
initializeExecutorService();
|
initializeExecutorService();
|
||||||
System.setProperty("java.library.path", this.getApplicationInfo().nativeLibraryDir);
|
System.setProperty("java.library.path", getApplicationInfo().nativeLibraryDir);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkAndRequestPermissions() {
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
|
||||||
if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE)
|
checkStoragePermission();
|
||||||
!= PackageManager.PERMISSION_GRANTED) {
|
|
||||||
ActivityCompat.requestPermissions(
|
|
||||||
this,
|
|
||||||
new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
|
|
||||||
REQUEST_CODE_STORAGE_PERMISSION
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
|
checkAllFilesAccessPermission();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkStoragePermission() {
|
||||||
|
if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE)
|
||||||
|
!= PackageManager.PERMISSION_GRANTED) {
|
||||||
|
ActivityCompat.requestPermissions(
|
||||||
|
this,
|
||||||
|
new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
|
||||||
|
REQUEST_CODE_STORAGE_PERMISSION
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkAllFilesAccessPermission() {
|
||||||
|
if (VERSION.SDK_INT >= VERSION_CODES.R) {
|
||||||
if (!Environment.isExternalStorageManager()) {
|
if (!Environment.isExternalStorageManager()) {
|
||||||
Intent intent = new Intent(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION);
|
Intent intent = new Intent(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION);
|
||||||
intent.setData(Uri.parse("package:" + getPackageName()));
|
intent.setData(Uri.parse(PACKAGE_SCHEME + getPackageName()));
|
||||||
startActivityForResult(intent, ALLOW_ALL_FILES_ACCESS_PERMISSION_CODE);
|
startActivityForResult(intent, ALLOW_ALL_FILES_ACCESS_PERMISSION_CODE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkNetworkConnection() {
|
||||||
if (!isNetworkAvailable(this)) {
|
if (!isNetworkAvailable(this)) {
|
||||||
Toast.makeText(this, "Network is not available", Toast.LENGTH_SHORT).show();
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "Network not available, closing app.", null);
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "Network not available, closing app.", null);
|
Toast.makeText(this, R.string.network_unavailable, Toast.LENGTH_SHORT).show();
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "onCreate: Setting up work manager", null);
|
private void setupWorkManager() {
|
||||||
PeriodicWorkRequest workRequest = new PeriodicWorkRequest.Builder(CheckAccessibilityWorker.class, 15, TimeUnit.MINUTES)
|
LogFileUtil.logAndWrite(Log.INFO, TAG, "onCreate: Setting up work manager", null);
|
||||||
.build();
|
PeriodicWorkRequest workRequest = new PeriodicWorkRequest.Builder(
|
||||||
|
CheckAccessibilityWorker.class,
|
||||||
|
15,
|
||||||
|
TimeUnit.MINUTES
|
||||||
|
).build();
|
||||||
WorkManager.getInstance(this).enqueue(workRequest);
|
WorkManager.getInstance(this).enqueue(workRequest);
|
||||||
|
}
|
||||||
|
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "onCreate: Setting up UI components", null);
|
// 添加切换国家的方法
|
||||||
Button runScriptButton = findViewById(R.id.run_script_button);
|
private void switchCountry() {
|
||||||
if (runScriptButton != null) {
|
currentCountry = currentCountry.equals(CountryCode.US) ?
|
||||||
runScriptButton.setOnClickListener(v -> {
|
CountryCode.RU : CountryCode.US;
|
||||||
initializeExecutorService();
|
LogFileUtil.logAndWrite(Log.INFO, TAG,
|
||||||
|
"Switched country to: " + currentCountry, null);
|
||||||
|
}
|
||||||
|
|
||||||
executorService.submit(() -> {
|
|
||||||
try {
|
|
||||||
TaskUtil.infoUpload(MainActivity.this, getAndroidId(MainActivity.this), "wsj.reader_sp");
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
// runScriptButton.setOnClickListener(v -> AutoJsUtil.runAutojsScript(this));
|
|
||||||
} else {
|
|
||||||
LogFileUtil.logAndWrite(Log.WARN, "MainActivity", "Run Script Button not found", null);
|
|
||||||
Toast.makeText(this, "Button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
Button connectButton = findViewById(R.id.connectVpnButton);
|
private void initializeButtons() {
|
||||||
if (connectButton != null) {
|
LogFileUtil.logAndWrite(Log.INFO, TAG, "onCreate: Setting up UI components", null);
|
||||||
connectButton.setOnClickListener(v -> startProxyVpn(this));
|
|
||||||
} else {
|
|
||||||
Toast.makeText(this, "Connect button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
Button disconnectButton = findViewById(R.id.disconnectVpnButton);
|
|
||||||
if (disconnectButton != null) {
|
|
||||||
disconnectButton.setOnClickListener(v -> ClashUtil.stopProxy(this));
|
|
||||||
} else {
|
|
||||||
Toast.makeText(this, "Disconnect button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
Button switchVpnButton = findViewById(R.id.switchVpnButton);
|
|
||||||
if (switchVpnButton != null) {
|
|
||||||
switchVpnButton.setOnClickListener(v -> ClashUtil.switchProxyGroup("GLOBAL", "us", "http://127.0.0.1:6170"));
|
|
||||||
} else {
|
|
||||||
Toast.makeText(this, "Disconnect button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Button modifyDeviceInfoButton = findViewById(R.id.modifyDeviceInfoButton);
|
|
||||||
// if (modifyDeviceInfoButton != null) {
|
|
||||||
// modifyDeviceInfoButton.setOnClickListener(v -> ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), this));
|
|
||||||
// } else {
|
|
||||||
// Toast.makeText(this, "modifyDeviceInfo button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
// }
|
|
||||||
|
|
||||||
Button resetDeviceInfoButton = findViewById(R.id.resetDeviceInfoButton);
|
|
||||||
if (resetDeviceInfoButton != null) {
|
|
||||||
resetDeviceInfoButton.setOnClickListener(v -> ChangeDeviceInfoUtil.resetChangedDeviceInfo(getPackageName(), this));
|
|
||||||
} else {
|
|
||||||
Toast.makeText(this, "resetDeviceInfo button not found", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化 ChangeDeviceInfoUtil
|
|
||||||
String androidId = getAndroidId(this);
|
String androidId = getAndroidId(this);
|
||||||
String taskId = UUID.randomUUID().toString();
|
String taskId = UUID.randomUUID().toString();
|
||||||
// ChangeDeviceInfoUtil.getAddDeviceInfo("US", 2);
|
|
||||||
// 获取输入框和按钮
|
setupButton(R.id.run_script_button, v -> executeRunScript(androidId));
|
||||||
|
setupButton(R.id.connectVpnButton, v -> startProxyVpn(this));
|
||||||
|
setupButton(R.id.disconnectVpnButton, v -> ClashUtil.stopProxy(this));
|
||||||
|
setupButton(R.id.switchVpnButton, v -> {
|
||||||
|
switchCountry();
|
||||||
|
ClashUtil.switchProxyGroup("GLOBAL", currentCountry, "http://127.0.0.1:6170");
|
||||||
|
});
|
||||||
|
setupButton(R.id.resetDeviceInfoButton,
|
||||||
|
v -> ChangeDeviceInfoUtil.resetChangedDeviceInfo(getPackageName(), this));
|
||||||
|
setupExecutionButtons(androidId, taskId);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void setupButton(@IdRes int buttonId, View.OnClickListener listener) {
|
||||||
|
Button button = findViewById(buttonId);
|
||||||
|
if (button != null) {
|
||||||
|
button.setOnClickListener(listener);
|
||||||
|
} else {
|
||||||
|
LogFileUtil.logAndWrite(Log.WARN, TAG, "Button not found: " + buttonId, null);
|
||||||
|
Toast.makeText(this, R.string.button_not_found, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void executeRunScript(String androidId) {
|
||||||
|
initializeExecutorService();
|
||||||
|
executorService.submit(() -> {
|
||||||
|
try {
|
||||||
|
TaskUtil.infoUpload(MainActivity.this, androidId, "wsj.reader_sp");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupExecutionButtons(String androidId, String taskId) {
|
||||||
Button executeButton = findViewById(R.id.execute_button);
|
Button executeButton = findViewById(R.id.execute_button);
|
||||||
Button stopExecuteButton = findViewById(R.id.stop_execute_button);
|
Button stopExecuteButton = findViewById(R.id.stop_execute_button);
|
||||||
|
|
||||||
// 设置按钮的点击事件
|
|
||||||
if (executeButton != null) {
|
if (executeButton != null) {
|
||||||
executeButton.setOnClickListener(v -> {
|
executeButton.setOnClickListener(v -> {
|
||||||
executeButton.setEnabled(false);
|
executeButton.setEnabled(false);
|
||||||
Toast.makeText(this, "任务正在执行", Toast.LENGTH_SHORT).show();
|
Toast.makeText(this, R.string.task_executing, Toast.LENGTH_SHORT).show();
|
||||||
executeLogic(androidId, taskId);
|
executeLogic(androidId, taskId);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setupStopExecutionButton(stopExecuteButton, executeButton);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupStopExecutionButton(Button stopExecuteButton, Button executeButton) {
|
||||||
if (stopExecuteButton != null) {
|
if (stopExecuteButton != null) {
|
||||||
stopExecuteButton.setOnClickListener(v -> {
|
stopExecuteButton.setOnClickListener(v -> {
|
||||||
if (executorService != null && !executorService.isShutdown()) {
|
if (executorService != null && !executorService.isShutdown()) {
|
||||||
|
@ -232,80 +265,95 @@ public class MainActivity extends AppCompatActivity {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
Toast.makeText(this, "Stop button not found", Toast.LENGTH_SHORT).show();
|
Toast.makeText(this, R.string.stop_button_not_found, Toast.LENGTH_SHORT).show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void executeLogic(String androidId, String taskId) {
|
private void executeLogic(String androidId, String taskId) {
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeLogic: Start execution", null);
|
LogFileUtil.logAndWrite(Log.INFO, TAG, "Start execution", null);
|
||||||
|
|
||||||
if (!isNetworkAvailable(this)) {
|
if (!isNetworkAvailable(this)) {
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "executeLogic: Network is not available!", null);
|
|
||||||
Toast.makeText(this, "网络不可用,请检查网络连接", Toast.LENGTH_SHORT).show();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeLogic: Submitting job to executor", null);
|
|
||||||
initializeExecutorService();
|
initializeExecutorService();
|
||||||
|
executorService.submit(() -> processMainTask(androidId, taskId));
|
||||||
|
}
|
||||||
|
|
||||||
executorService.submit(() -> {
|
private void processMainTask(String androidId, String taskId) {
|
||||||
try {
|
try {
|
||||||
ChangeDeviceInfoUtil.getAddDeviceInfo("US", 2, (bigoDevice, afDevice) -> {
|
initializeDeviceAndRunScript();
|
||||||
startProxyVpn(MainActivity.this);
|
processScriptResults(androidId, taskId);
|
||||||
ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), MainActivity.this, bigoDevice, afDevice);
|
} catch (Exception e) {
|
||||||
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "Unexpected task error", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializeDeviceAndRunScript() {
|
||||||
|
ChangeDeviceInfoUtil.getAddDeviceInfo(currentCountry.toUpperCase(), DEVICE_TYPE,
|
||||||
|
(bigoDevice, afDevice) -> {
|
||||||
|
startProxyVpn(this);
|
||||||
|
ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), this,
|
||||||
|
bigoDevice, afDevice);
|
||||||
AutoJsUtil.runAutojsScript(this);
|
AutoJsUtil.runAutojsScript(this);
|
||||||
});
|
});
|
||||||
AutoJsUtil.registerScriptResultReceiver(this);
|
AutoJsUtil.registerScriptResultReceiver(this);
|
||||||
|
|
||||||
while (isRunning) {
|
|
||||||
if (!isRunning) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeSingleLogic: Running AutoJs script", null);
|
|
||||||
String currentScriptResult = scriptResultQueue.take();
|
|
||||||
ChangeDeviceInfoUtil.getAddDeviceInfo("US", 2, (bigoDevice, afDevice) -> {
|
|
||||||
try {
|
|
||||||
startProxyVpn(MainActivity.this);
|
|
||||||
ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), MainActivity.this, bigoDevice, afDevice);
|
|
||||||
AutoJsUtil.runAutojsScript(this);
|
|
||||||
if (currentScriptResult != null && !TextUtils.isEmpty(currentScriptResult)) {
|
|
||||||
TaskUtil.execSaveTask(this, androidId, taskId, currentScriptResult, IpUtil.fetchGeoInfo());
|
|
||||||
infoUpload(this, androidId, currentScriptResult);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "changeDeviceInfo erro", e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
LogFileUtil.logAndWrite(android.util.Log.DEBUG, "MainActivity", "----发送result------;" + currentScriptResult, null);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
Thread.currentThread().interrupt();
|
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "loop: Thread interrupted while waiting", e);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "loop erro", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "start executeLogic: Unexpected task error.", e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void processScriptResults(String androidId, String taskId) {
|
||||||
|
while (isRunning) {
|
||||||
|
try {
|
||||||
|
String currentScriptResult = scriptResultQueue.take();
|
||||||
|
if (!isRunning) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
processScriptResult(androidId, taskId, currentScriptResult);
|
||||||
|
LogFileUtil.logAndWrite(Log.DEBUG, TAG, "Script result processed: " + currentScriptResult, null);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "Thread interrupted while waiting", e);
|
||||||
|
break;
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "Error processing script result", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void processScriptResult(String androidId, String taskId, String result) {
|
||||||
|
|
||||||
|
ChangeDeviceInfoUtil.getAddDeviceInfo(currentCountry.toUpperCase(), DEVICE_TYPE,
|
||||||
|
(bigoDevice, afDevice) -> {
|
||||||
|
try {
|
||||||
|
updateDeviceAndExecuteTask(androidId, taskId, result, bigoDevice, afDevice);
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "Device info change error", e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void updateDeviceAndExecuteTask(String androidId, String taskId,
|
||||||
|
String result, JSONObject bigoDevice, JSONObject afDevice) {
|
||||||
|
startProxyVpn(this);
|
||||||
|
ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), this, bigoDevice, afDevice);
|
||||||
|
AutoJsUtil.runAutojsScript(this);
|
||||||
|
|
||||||
|
TaskUtil.execSaveTask(this, androidId, taskId, result, IpUtil.fetchGeoInfo());
|
||||||
|
try {
|
||||||
|
infoUpload(this, androidId, result);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public static final LinkedBlockingQueue<String> scriptResultQueue = new LinkedBlockingQueue<>(1);
|
public static final LinkedBlockingQueue<String> scriptResultQueue = new LinkedBlockingQueue<>(1);
|
||||||
private volatile boolean isRunning = true; // 主线程运行状态
|
private volatile boolean isRunning = true; // 主线程运行状态
|
||||||
public static final Object taskLock = new Object(); // 任务逻辑锁
|
public static final Object taskLock = new Object(); // 任务逻辑锁
|
||||||
|
|
||||||
// public void executeSingleLogic() {
|
|
||||||
//// LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeSingleLogic: Proxy not active, starting VPN",null);
|
|
||||||
// startProxyVpn(this);
|
|
||||||
// LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeSingleLogic: Changing device info",null);
|
|
||||||
// ChangeDeviceInfoUtil.changeDeviceInfo(getPackageName(), this);
|
|
||||||
|
|
||||||
/// / LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "executeSingleLogic: Running AutoJs script",null);
|
|
||||||
///
|
|
||||||
/// @return
|
|
||||||
// AutoJsUtil.runAutojsScript(this);
|
|
||||||
// }
|
|
||||||
private void startProxyVpn(Context context) {
|
private void startProxyVpn(Context context) {
|
||||||
if (!isNetworkAvailable(context)) {
|
if (!isNetworkAvailable(context)) {
|
||||||
Toast.makeText(context, "Network is not available", Toast.LENGTH_SHORT).show();
|
Toast.makeText(context, "Network is not available", Toast.LENGTH_SHORT).show();
|
||||||
|
@ -317,11 +365,14 @@ public class MainActivity extends AppCompatActivity {
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "startProxyVpn: Context is not an Activity.", null);
|
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "startProxyVpn: Context is not an Activity.", null);
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
ClashUtil.startProxy(context); // 在主线程中调用
|
ClashUtil.startProxy(context);
|
||||||
ClashUtil.switchProxyGroup("GLOBAL", "us", "http://127.0.0.1:6170");
|
// 使用相同的国家代码
|
||||||
|
ClashUtil.switchProxyGroup("GLOBAL", currentCountry, "http://127.0.0.1:6170");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogFileUtil.logAndWrite(Log.ERROR, "MainActivity", "startProxyVpn: Failed to start VPN", e);
|
LogFileUtil.logAndWrite(Log.ERROR, TAG, "startProxyVpn: Failed to start VPN", e);
|
||||||
Toast.makeText(context, "Failed to start VPN: " + (e.getMessage() != null ? e.getMessage() : "Unknown error"), Toast.LENGTH_SHORT).show();
|
Toast.makeText(context, "Failed to start VPN: " +
|
||||||
|
(e.getMessage() != null ? e.getMessage() : "Unknown error"),
|
||||||
|
Toast.LENGTH_SHORT).show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -414,9 +465,6 @@ public class MainActivity extends AppCompatActivity {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static MainActivity getInstance() {
|
|
||||||
return instance.get(); // 返回实例
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean isNetworkAvailable(Context context) {
|
private boolean isNetworkAvailable(Context context) {
|
||||||
ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
|
|
|
@ -53,27 +53,6 @@ public class ChangeDeviceInfoUtil {
|
||||||
// 创建一个线程池用于执行网络任务
|
// 创建一个线程池用于执行网络任务
|
||||||
private static final ExecutorService executorService = Executors.newSingleThreadExecutor();
|
private static final ExecutorService executorService = Executors.newSingleThreadExecutor();
|
||||||
|
|
||||||
public static void initialize(String country, int tag, Context context, String androidId) {
|
|
||||||
LogFileUtil.logAndWrite(android.util.Log.DEBUG, LOG_TAG, "Initializing device info...", null);
|
|
||||||
|
|
||||||
executorService.submit(() -> {
|
|
||||||
try {
|
|
||||||
LogFileUtil.logAndWrite(android.util.Log.DEBUG, LOG_TAG, "Starting network requests...", null);
|
|
||||||
String bigoJson = fetchJsonSafely(buildBigoUrl(country, tag), "bigoJson");
|
|
||||||
String afJson = fetchJsonSafely(buildAfUrl(country, tag), "afJson");
|
|
||||||
|
|
||||||
fallBackToNetworkData(bigoJson, afJson);
|
|
||||||
|
|
||||||
logDeviceObjects();
|
|
||||||
processPackageInfo(TaskUtil.getPackageInfo(androidId), context);
|
|
||||||
|
|
||||||
} catch (IOException | JSONException e) {
|
|
||||||
LogFileUtil.logAndWrite(android.util.Log.ERROR, LOG_TAG, "Error occurred during initialization", e);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogFileUtil.logAndWrite(android.util.Log.ERROR, LOG_TAG, "Error occurred during initialization", e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void getAddDeviceInfo(String country, int tag, LoadDeviceCallback callback){
|
public static void getAddDeviceInfo(String country, int tag, LoadDeviceCallback callback){
|
||||||
LogFileUtil.logAndWrite(android.util.Log.DEBUG, LOG_TAG, "Initializing device info...", null);
|
LogFileUtil.logAndWrite(android.util.Log.DEBUG, LOG_TAG, "Initializing device info...", null);
|
||||||
|
|
|
@ -1,4 +1,8 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">study_app</string>
|
<string name="app_name">study_app</string>
|
||||||
<string name="accessibility_service_description">This is an accessibility service.</string>
|
<string name="accessibility_service_description">This is an accessibility service.</string>
|
||||||
|
<string name="task_executing">任务执行中</string>
|
||||||
|
<string name="button_not_found">按钮未找到</string>
|
||||||
|
<string name="network_unavailable">网络不可用</string>
|
||||||
|
<string name="stop_button_not_found">停止按钮未找到</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Reference in New Issue