2020-04-24 21:40:03 +01:00
|
|
|
const chalk = require('chalk');
|
|
|
|
const common = require('../lib/common');
|
|
|
|
const inquirer = require('../lib/inquirer');
|
2020-04-25 10:27:17 +01:00
|
|
|
const files = require('../lib/files')
|
2020-08-28 15:29:38 +01:00
|
|
|
const logger = require('perfect-logger');
|
2020-08-28 13:03:24 +01:00
|
|
|
const Language = require("@shypes/language-translator");
|
|
|
|
const adb = require('../lib/adb');
|
2020-08-27 16:45:49 +01:00
|
|
|
|
|
|
|
logger.info(process.platform + " detected")
|
|
|
|
if (process.platform === 'win32' || process.platform === 'win64') {
|
|
|
|
adbRun = 'adb'
|
|
|
|
} else {
|
|
|
|
adbRun = './adb'
|
|
|
|
}
|
2020-04-25 23:07:43 +01:00
|
|
|
|
2020-04-30 09:03:50 +01:00
|
|
|
logger.initialize('RunTIme', {
|
2020-06-02 10:55:53 +01:00
|
|
|
logLevelFile: 0, // Log level for file
|
|
|
|
logLevelConsole: -1, // Log level for STDOUT/STDERR
|
|
|
|
logDirectory: 'data/', // Log directory
|
2020-04-30 09:03:50 +01:00
|
|
|
});
|
|
|
|
|
2020-04-24 21:40:03 +01:00
|
|
|
module.exports = {
|
2020-04-27 12:40:59 +01:00
|
|
|
removeCompatibleApps: async () => {
|
2020-08-28 13:03:24 +01:00
|
|
|
common.header(await Language.get('remove_installed_apps_header'))
|
|
|
|
logger.info(await Language.get('remove_installed_apps_header'))
|
2020-04-28 12:00:45 +01:00
|
|
|
|
2020-08-28 13:03:24 +01:00
|
|
|
value = await adb.getInstalledPacakges()
|
|
|
|
|
|
|
|
for (let element of value.removeAppsList) {
|
2020-08-28 15:29:38 +01:00
|
|
|
console.log(await Language.get('removing') + ' ' + element)
|
|
|
|
logger.info(await Language.get('removing') + ' ' + element)
|
|
|
|
const package = element.substring(8)
|
|
|
|
await adb.removeApk(package)
|
2020-08-28 13:03:24 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green(await Language.get('remove_selected_user_apps')))
|
|
|
|
logger.info(await Language.get('remove_selected_user_apps'))
|
|
|
|
await common.pause(2000)
|
|
|
|
module.exports.mainMenu()
|
2020-08-28 15:29:38 +01:00
|
|
|
|
2020-04-27 12:40:59 +01:00
|
|
|
},
|
2020-08-28 15:29:38 +01:00
|
|
|
installCompatibleApps: async () => {
|
2020-08-28 13:03:24 +01:00
|
|
|
logger.info(await Language.get('install_compatible_apps_header'))
|
|
|
|
common.header(await Language.get('install_compatible_apps_header'))
|
2020-04-26 09:39:33 +01:00
|
|
|
|
2020-08-27 10:28:54 +01:00
|
|
|
const compatibleApps = await common.getCompatibleAppsList()
|
2020-04-26 10:10:29 +01:00
|
|
|
const value = await inquirer.compatibleApps();
|
|
|
|
|
2020-08-27 17:10:47 +01:00
|
|
|
await common.clearApkFolder()
|
2020-04-26 10:10:29 +01:00
|
|
|
|
2020-04-25 16:26:34 +01:00
|
|
|
for (let element of value.removeAppsList) {
|
2020-04-25 16:56:23 +01:00
|
|
|
for (let element2 of compatibleApps) {
|
|
|
|
if (element === element2.name) {
|
2020-08-27 11:42:00 +01:00
|
|
|
newName = element.replace(/\s/g, '');
|
|
|
|
await common.downloadFile(element2.url, './data/apps/' + newName + '.apk')
|
2020-04-25 16:56:23 +01:00
|
|
|
}
|
|
|
|
}
|
2020-04-25 16:26:34 +01:00
|
|
|
}
|
2020-04-26 09:39:33 +01:00
|
|
|
|
2020-08-28 15:29:38 +01:00
|
|
|
const apkList = await files.getListOfAPk('./data/apps')
|
2020-04-26 09:39:33 +01:00
|
|
|
|
2020-08-28 15:29:38 +01:00
|
|
|
for (let package of apkList) {
|
|
|
|
console.log(await Language.get('installing') + ' ' + package)
|
|
|
|
logger.info(await Language.get('installing') + ' ' + package)
|
|
|
|
await adb.installApk(package)
|
2020-04-27 12:24:32 +01:00
|
|
|
}
|
2020-08-28 13:03:24 +01:00
|
|
|
console.log(chalk.green(await Language.get('compatible_apps_installed')))
|
|
|
|
logger.info(await Language.get('compatible_apps_installed'))
|
2020-04-27 12:24:32 +01:00
|
|
|
await common.pause(2000)
|
|
|
|
module.exports.mainMenu()
|
|
|
|
},
|
|
|
|
removeApps: async () => {
|
2020-04-30 09:03:50 +01:00
|
|
|
logger.info("Remove Apps")
|
2020-04-25 10:44:12 +01:00
|
|
|
common.header('Remove Apps')
|
2020-04-25 14:21:45 +01:00
|
|
|
const value = await inquirer.removeAppsList();
|
2020-08-28 15:29:38 +01:00
|
|
|
for (let package of value.removeAppsList) {
|
|
|
|
await adb.removeXiaomiApk(package)
|
2020-04-25 14:21:45 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green('Removal Complete'))
|
|
|
|
await common.pause(2000)
|
2020-04-30 09:03:50 +01:00
|
|
|
logger.info("Remove Complete")
|
2020-04-25 14:21:45 +01:00
|
|
|
module.exports.mainMenu()
|
2020-04-25 11:06:05 +01:00
|
|
|
},
|
|
|
|
restoreApps: async () => {
|
2020-04-30 09:03:50 +01:00
|
|
|
logger.info("Restore Apps")
|
2020-04-27 12:24:32 +01:00
|
|
|
common.header('Restore Apps')
|
|
|
|
const value = await inquirer.removeAppsList();
|
2020-08-28 15:29:38 +01:00
|
|
|
for (let package of value.removeAppsList) {
|
|
|
|
await adb.restoreXiaomiApk(package)
|
2020-04-27 12:24:32 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green('Restore Complete'))
|
|
|
|
await common.pause(2000)
|
2020-04-30 09:03:50 +01:00
|
|
|
logger.info("Restore Apps Complete")
|
2020-04-27 12:24:32 +01:00
|
|
|
module.exports.mainMenu()
|
|
|
|
},
|
2020-08-27 16:45:49 +01:00
|
|
|
connectWatch: async () => {
|
|
|
|
logger.info("Connect to watch")
|
|
|
|
common.header('Connect to watch')
|
|
|
|
const value = await inquirer.connectionType()
|
2020-08-28 15:29:38 +01:00
|
|
|
connected = await adb.watchConnection(value)
|
|
|
|
if (connected != true) {
|
|
|
|
module.exports.connectWatch()
|
|
|
|
} else {
|
|
|
|
module.exports.mainMenu()
|
2020-04-27 12:24:32 +01:00
|
|
|
}
|
|
|
|
},
|
2020-08-26 17:22:31 +01:00
|
|
|
oneClick: async () => {
|
|
|
|
logger.info("1-Click Karl0ss Klean")
|
|
|
|
common.header('1-Click Karl0ss Klean')
|
2020-08-27 10:28:54 +01:00
|
|
|
const removalPackagesList = files.loadPackageList()
|
2020-08-28 15:29:38 +01:00
|
|
|
for (let package of removalPackagesList.apps) {
|
|
|
|
await adb.removeXiaomiApk(package)
|
2020-08-26 17:22:31 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green('Removal Complete'))
|
|
|
|
await common.pause(2000)
|
|
|
|
logger.info("Remove Complete")
|
|
|
|
logger.info("Compatible Apps")
|
|
|
|
|
2020-08-27 17:10:47 +01:00
|
|
|
await common.clearApkFolder()
|
2020-08-26 17:22:31 +01:00
|
|
|
|
2020-08-27 10:28:54 +01:00
|
|
|
const compatibleApps = await common.getCompatibleAppsList()
|
2020-08-28 15:29:38 +01:00
|
|
|
console.log(chalk.green('Download Compatible APKS'))
|
2020-08-26 17:22:31 +01:00
|
|
|
|
2020-08-28 15:29:38 +01:00
|
|
|
for (const package of compatibleApps) {
|
|
|
|
if (package.Klean === "X") {
|
2020-08-27 10:28:54 +01:00
|
|
|
try {
|
2020-08-28 15:29:38 +01:00
|
|
|
newPacakgeName = package.name.replace(/\s/g, '');
|
|
|
|
await common.downloadFile(package.url, './data/apps/' + newPacakgeName + '.apk')
|
|
|
|
logger.info('Downloading Latest ' + package.name + ' Complete')
|
|
|
|
console.log('Downloading Latest ' + package.name + ' Complete')
|
2020-08-27 10:28:54 +01:00
|
|
|
} catch (error) {
|
2020-08-28 15:29:38 +01:00
|
|
|
logger.info('Downloading Latest ' + package.name + ' FAILED')
|
2020-08-27 10:28:54 +01:00
|
|
|
}
|
2020-08-26 17:22:31 +01:00
|
|
|
}
|
|
|
|
}
|
2020-08-28 15:29:38 +01:00
|
|
|
const apkList = await files.getListOfAPk('./data/apps')
|
|
|
|
console.log(chalk.green('Install Apks'))
|
2020-08-26 17:22:31 +01:00
|
|
|
for (let element of apkList) {
|
2020-08-28 15:29:38 +01:00
|
|
|
await adb.installApk(element)
|
2020-08-26 17:22:31 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green('Compatible Apps Installed'))
|
|
|
|
logger.info('Compatible Apps Installed')
|
|
|
|
await common.pause(2000)
|
|
|
|
module.exports.mainMenu()
|
|
|
|
},
|
2020-08-27 10:28:54 +01:00
|
|
|
restoreAnyApp: async () => {
|
|
|
|
logger.info("Restore Any App")
|
|
|
|
common.header('Restore Any App')
|
|
|
|
const value = await inquirer.restoreAnyApp();
|
2020-08-28 15:29:38 +01:00
|
|
|
await adb.restoreAnyApk(value)
|
2020-08-27 10:28:54 +01:00
|
|
|
console.log(chalk.green('Restore Complete'))
|
|
|
|
await common.pause(2000)
|
|
|
|
logger.info("App Restore Complete")
|
|
|
|
module.exports.mainMenu()
|
|
|
|
},
|
2020-08-27 18:16:39 +01:00
|
|
|
batchInstallApks: async () => {
|
|
|
|
logger.info("Batch Install Apks")
|
|
|
|
common.header('Batch Install Apks')
|
|
|
|
|
2020-08-28 15:29:38 +01:00
|
|
|
let apkList = await files.getListOfAPk('./my_apk/')
|
2020-08-27 18:16:39 +01:00
|
|
|
await files.renameLocalApk(apkList)
|
2020-08-28 15:29:38 +01:00
|
|
|
apkList = await files.getListOfAPk('./my_apk/')
|
2020-08-27 18:16:39 +01:00
|
|
|
|
|
|
|
for (let element of apkList) {
|
|
|
|
console.log('Installing ' + element)
|
|
|
|
logger.info('Installing ' + element)
|
2020-08-28 15:29:38 +01:00
|
|
|
await adb.installApk(element)
|
2020-08-27 18:16:39 +01:00
|
|
|
}
|
|
|
|
console.log(chalk.green('Batch Install Apks Completed'))
|
|
|
|
logger.info('Batch Install Apks Completed')
|
|
|
|
await common.pause(2000)
|
|
|
|
module.exports.mainMenu()
|
|
|
|
},
|
2020-04-27 12:24:32 +01:00
|
|
|
mainMenu: async () => {
|
|
|
|
common.header('Main Menu')
|
|
|
|
const mainMenuSelection = await inquirer.mainMenu();
|
|
|
|
switch (mainMenuSelection.mainMenu) {
|
2020-08-27 16:45:49 +01:00
|
|
|
case 'connect to miwatch':
|
|
|
|
module.exports.connectWatch()
|
2020-04-27 12:24:32 +01:00
|
|
|
break;
|
2020-08-26 17:22:31 +01:00
|
|
|
case '1-click karl0ss klean':
|
|
|
|
module.exports.oneClick()
|
|
|
|
break;
|
2020-04-27 12:24:32 +01:00
|
|
|
case 'remove xiaomi apps':
|
|
|
|
module.exports.removeApps()
|
|
|
|
break;
|
|
|
|
case 'restore xiaomi apps':
|
|
|
|
module.exports.restoreApps()
|
|
|
|
break;
|
|
|
|
case 'install compatible apps':
|
2020-08-28 15:29:38 +01:00
|
|
|
module.exports.installCompatibleApps()
|
2020-04-27 12:24:32 +01:00
|
|
|
break;
|
2020-08-27 18:16:39 +01:00
|
|
|
case 'batch remove installed apps':
|
2020-04-27 12:40:59 +01:00
|
|
|
module.exports.removeCompatibleApps()
|
2020-04-28 11:24:10 +01:00
|
|
|
break;
|
2020-08-27 10:28:54 +01:00
|
|
|
case 'restore any app':
|
|
|
|
module.exports.restoreAnyApp()
|
|
|
|
break;
|
2020-08-27 18:16:39 +01:00
|
|
|
case 'batch install apks':
|
|
|
|
module.exports.batchInstallApks()
|
|
|
|
break;
|
2020-04-27 12:24:32 +01:00
|
|
|
case 'quit':
|
|
|
|
break;
|
|
|
|
default:
|
2020-04-28 13:02:35 +01:00
|
|
|
// code block
|
2020-04-27 12:24:32 +01:00
|
|
|
}
|
|
|
|
}
|
2020-04-24 21:40:03 +01:00
|
|
|
};
|