323 lines
15 KiB
JavaScript
Raw Normal View History

2020-04-24 21:40:03 +01:00
const chalk = require('chalk');
const common = require('../lib/common');
const inquirer = require('../lib/inquirer');
2020-04-24 22:20:41 +01:00
const shellExec = require('shell-exec')
2020-04-25 10:27:17 +01:00
const files = require('../lib/files')
2020-04-25 14:54:31 +01:00
const fs = require('fs')
2020-04-26 09:39:33 +01:00
const getFilesIn = require('get-files-in')
2020-04-26 11:08:29 +01:00
var shell = require('shelljs');
2020-04-30 09:03:50 +01:00
let logger = require('perfect-logger');
2020-04-26 11:08:29 +01:00
2020-04-28 11:24:10 +01:00
let adbRun
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 () => {
let installedAppList
common.header('Remove Installed Apps')
2020-04-30 09:03:50 +01:00
logger.info('Remove Installed Apps')
await shellExec(adbRun + ' shell pm list packages -3').then(async function (result) {
2020-04-30 09:03:50 +01:00
logger.info('Packages recieved from watch')
2020-04-29 09:09:01 +01:00
if (result.stderr.includes('error')) {
2020-04-30 09:03:50 +01:00
logger.info(result.stderr)
2020-04-29 09:09:01 +01:00
console.log(chalk.red('Device not authorised'))
common.pause(3000)
await shellExec(adbRun + ' kill-server').then(async function (result) {
2020-04-30 09:03:50 +01:00
logger.info('Restarting ADB')
logger.info(result.stdout)
2020-04-29 09:09:01 +01:00
console.log('Please reconnect to watch')
common.pause(3000)
2020-04-30 09:03:50 +01:00
logger.info('Remove Installed Apps Failed')
2020-04-29 09:09:01 +01:00
module.exports.mainMenu()
})
2020-04-28 13:02:35 +01:00
} else {
2020-04-29 09:09:01 +01:00
if (process.platform === 'win32' || process.platform === 'win64') {
installedAppList = result.stdout.split('\r\n'); // split string on comma space
installedAppList.splice(-1, 1)
} else {
installedAppList = result.stdout.split('\n'); // split string on comma space
installedAppList.splice(-1, 1)
}
const value = await inquirer.installedApps(installedAppList);
2020-04-30 15:57:48 +01:00
for (let element of value.removeAppsList) {
console.log('Removing ' + element)
logger.info('Removing ' + element)
const package = element.substring(8)
await shellExec(adbRun + ' uninstall ' + package).then(async function (result) {
console.log(element + ' - ' + result.stdout);
logger.info(element + ' - ' + result.stdout);
});
}
console.log(chalk.green('Removed Selected User Apps'))
logger.info('Removed Selected User Apps')
await common.pause(2000)
module.exports.mainMenu()
2020-04-29 09:09:01 +01:00
}
2020-04-30 15:57:48 +01:00
})
2020-04-27 12:40:59 +01:00
},
2020-04-25 15:35:15 +01:00
compatibleApps: async () => {
2020-04-30 09:03:50 +01:00
logger.info("Compatible Apps")
2020-04-25 15:35:15 +01:00
common.header('Install Compatible Apps')
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-04-26 11:08:29 +01:00
await shell.rm('-rf', './data/apps/*.apk');
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 10:28:54 +01:00
await common.downloadFile(element2.url, './data/apps/' + element2.name + '.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
const apkList = await getFilesIn('./data/apps', matchFiletypes = ['apk'], checkSubDirectories = false)
for (let element of apkList) {
2020-04-26 10:10:29 +01:00
console.log('Installing ' + element)
2020-04-30 09:03:50 +01:00
logger.info('Installing ' + element)
2020-04-28 11:24:10 +01:00
await shellExec(adbRun + ' install -r ' + element).then(async function (result) {
2020-04-30 15:57:48 +01:00
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
2020-04-30 16:00:40 +01:00
console.log(chalk.redBright('Error - Device not authorised'));
2020-04-30 15:57:48 +01:00
}
2020-04-28 11:24:10 +01:00
console.log(element + ' - ' + result.stdout);
2020-04-30 09:03:50 +01:00
logger.info(element + ' - ' + result.stdout);
2020-06-24 09:17:36 +01:00
2020-08-26 09:58:06 +01:00
if (element === "data\\apps\\simpleweather_base.apk") {
2020-08-27 10:28:54 +01:00
await common.downloadFile('http://kithub.cf/Karl/MiWatchKleaner-APKs/raw/master/Others/simpleweather_split_config.armeabi_v7a.apk', './data/apps/simpleweather_split_config.armeabi_v7a.apk')
await common.downloadFile('http://kithub.cf/Karl/MiWatchKleaner-APKs/raw/master/Others/simpleweather_split_config.xhdpi.apk', './data/apps/simpleweather_split_config.xhdpi.apk')
2020-08-26 09:58:06 +01:00
await shellExec(adbRun + ' install-multiple "data\\apps\\simpleweather_base.apk" "data\\apps\\simpleweather_split_config.armeabi_v7a.apk" "data\\apps\\simpleweather_split_config.xhdpi.apk"').then(function (result) {
console.log(result)
2020-08-26 17:22:31 +01:00
console.log('simpleWeather Activated On Watch');
logger.info('simpleWeather Activated On Watch');
2020-08-26 09:58:06 +01:00
})
}
if (element === "data\\apps\\MoreLocale.apk") {
await shellExec(adbRun + ' shell pm grant jp.co.c_lis.ccl.morelocale android.permission.CHANGE_CONFIGURATION').then(function (result) {
console.log('moreLocale Activated On Watch');
logger.info('moreLocale Activated On Watch');
})
}
2020-06-24 09:17:36 +01:00
if (element === "data\\apps\\com.alberto.locale.apk") {
await shellExec(adbRun + ' shell pm grant com.alberto.locale android.permission.CHANGE_CONFIGURATION && ' + adbRun + ' shell am start -n com.alberto.locale/com.alberto.locale.MainActivity && ' + adbRun + ' shell pm grant com.alberto.locale android.permission.CHANGE_CONFIGURATION').then(function (result) {
console.log(result)
console.log('Alberto Locale Activated On Watch');
logger.info('Alberto Locale Activated On Watch');
2020-04-28 11:24:10 +01:00
});
}
});
2020-04-27 12:24:32 +01:00
}
console.log(chalk.green('Compatible Apps Installed'))
2020-04-30 09:03:50 +01:00
logger.info('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();
for (let element of value.removeAppsList) {
2020-08-26 13:14:15 +01:00
// await shellExec(adbRun + ' shell pm disable-user --0 ' + element).then(function (result) {
2020-04-28 11:24:10 +01:00
await shellExec(adbRun + ' shell pm uninstall -k --user 0 ' + element).then(function (result) {
2020-04-30 15:57:48 +01:00
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
2020-06-02 10:55:53 +01:00
logger.info('Removing ' + element + ' - ' + result.stdout);
console.log('Removing ' + element + ' - ' + result.stdout);
}
2020-04-28 11:24:10 +01:00
});
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();
for (let element of value.removeAppsList) {
2020-04-28 11:24:10 +01:00
await shellExec(adbRun + ' shell cmd package install-existing ' + element).then(function (result) {
2020-04-30 15:57:48 +01:00
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
2020-06-02 10:55:53 +01:00
logger.info('Restoring ' + element + ' - ' + result.stdout);
console.log('Restoring ' + element + ' - ' + result.stdout);
2020-04-30 15:57:48 +01:00
}
2020-04-28 11:24:10 +01:00
});
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()
},
connectWifi: async () => {
2020-04-30 09:03:50 +01:00
logger.info("Connect Wifi")
2020-04-27 12:24:32 +01:00
const miwatchData = JSON.parse(fs.readFileSync('./data/MiWatch.json', 'utf8'));
common.header('Connect Wifi')
if (miwatchData.ipAddress !== "") {
2020-04-30 15:47:37 +01:00
await shellExec(adbRun + ' kill-server')
2020-04-27 12:24:32 +01:00
console.log('Trying to connect with stored ipAddress')
2020-04-28 11:24:10 +01:00
shellExec(adbRun + ' connect ' + miwatchData.ipAddress).then(async function (result) {
2020-04-30 09:03:50 +01:00
logger.info("Connect Wifi Result " + result.stdout)
2020-04-28 11:24:10 +01:00
if (result.stdout.includes('already connected') || result.stdout.includes('connected to ')) {
console.log(chalk.green('MiWatch Connected'))
await common.pause(3000)
2020-04-30 09:03:50 +01:00
logger.info("Connect Wifi Complete")
2020-04-28 11:24:10 +01:00
module.exports.mainMenu()
} else {
console.log(chalk.red('MiWatch not found'))
await common.pause(2000)
2020-04-29 09:09:01 +01:00
files.writeIpAddress('')
2020-04-28 11:24:10 +01:00
console.log(chalk.white('Try Again'))
await common.pause(1000)
module.exports.connectWifi()
}
}).catch()
2020-04-27 12:24:32 +01:00
} else {
2020-04-30 15:47:37 +01:00
await shellExec(adbRun + ' kill-server')
2020-04-27 12:24:32 +01:00
const value = await inquirer.connectWifi();
const miWatchIpaddress = value.connectWifi
2020-04-28 11:24:10 +01:00
shellExec(adbRun + ' connect ' + miWatchIpaddress).then(async function (result) {
2020-04-30 09:03:50 +01:00
logger.info("Connect Wifi Result " + result.stdout)
2020-04-28 11:24:10 +01:00
if (result.stdout.includes('already connected') || result.stdout.includes('connected to ')) {
console.log(chalk.green('MiWatch Connected'))
files.writeIpAddress(miWatchIpaddress)
await common.pause(3000)
2020-04-30 09:03:50 +01:00
logger.info("Connect Wifi Complete")
2020-04-28 11:24:10 +01:00
module.exports.mainMenu()
} else {
2020-04-30 15:57:48 +01:00
if (result.stdout.includes('failed to authenticate')) {
console.log(chalk.redBright('MiWatch not authenticated'))
} else {
console.log(chalk.red('MiWatch not found'))
}
2020-04-28 11:24:10 +01:00
await common.pause(2000)
console.log(chalk.white('Try Again'))
await common.pause(1000)
module.exports.connectWifi()
}
}).catch()
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()
for (let element of removalPackagesList.apps) {
2020-08-26 17:22:31 +01:00
await shellExec(adbRun + ' shell pm uninstall -k --user 0 ' + element).then(function (result) {
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Removing ' + element + ' - ' + result.stdout);
console.log('Removing ' + element + ' - ' + result.stdout);
}
});
}
console.log(chalk.green('Removal Complete'))
await common.pause(2000)
logger.info("Remove Complete")
logger.info("Compatible Apps")
await shell.rm('-rf', './data/apps/*.apk');
2020-08-27 10:28:54 +01:00
const compatibleApps = await common.getCompatibleAppsList()
2020-08-26 17:22:31 +01:00
for (const element of compatibleApps) {
if (element.Klean === "X") {
2020-08-27 10:28:54 +01:00
try {
logger.info('Downloading Latest ' + element.name + ' Complete')
await common.downloadFile(element.url, './data/apps/' + element.name + '.apk')
2020-08-26 17:22:31 +01:00
logger.info('Downloading Latest ' + element.name + ' Complete')
2020-08-27 10:28:54 +01:00
} catch (error) {
logger.info('Downloading Latest ' + element.name + ' FAILED')
}
2020-08-26 17:22:31 +01:00
}
}
const apkList = await getFilesIn('./data/apps', matchFiletypes = ['apk'], checkSubDirectories = false)
for (let element of apkList) {
console.log('Installing ' + element)
logger.info('Installing ' + element)
await shellExec(adbRun + ' install -r ' + element).then(async function (result) {
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
}
console.log(element + ' - ' + result.stdout);
logger.info(element + ' - ' + result.stdout);
});
}
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();
await shellExec(adbRun + ' shell cmd package install-existing ' + value.restoreAnyApp).then(function (result) {
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Restoring ' + value.restoreAnyApp + ' - ' + result.stdout);
console.log('Restoring ' + value.restoreAnyApp + ' - ' + result.stdout);
}
});
console.log(chalk.green('Restore Complete'))
await common.pause(2000)
logger.info("App Restore Complete")
module.exports.mainMenu()
},
2020-04-27 12:24:32 +01:00
mainMenu: async () => {
common.header('Main Menu')
2020-04-28 11:24:10 +01:00
if (process.platform === 'win32' || process.platform === 'win64') {
adbRun = 'adb'
} else {
adbRun = './adb'
}
2020-04-30 09:03:50 +01:00
logger.info(process.platform + " detected")
2020-04-27 12:24:32 +01:00
const mainMenuSelection = await inquirer.mainMenu();
switch (mainMenuSelection.mainMenu) {
case 'connect to miwatch via wifi':
module.exports.connectWifi()
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':
module.exports.compatibleApps()
break;
case '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-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
};