lost of deduplication and code cleanup

This commit is contained in:
karl.hudgell 2020-08-28 15:29:38 +01:00
parent 73ee55d913
commit 1c47cbcd02
5 changed files with 143 additions and 151 deletions

View File

@ -1,7 +1,6 @@
{ {
"apps": [ "apps": [
"com.android.messaging", "com.android.messaging",
"com.eg.android.AlipayGphone",
"com.google.android.clockwork.flashlight", "com.google.android.clockwork.flashlight",
"com.google.android.clockwork.gestures.tutorial", "com.google.android.clockwork.gestures.tutorial",
"com.google.android.clockwork.lesetup", "com.google.android.clockwork.lesetup",
@ -12,7 +11,6 @@
"com.google.android.wearable.overlay.common.baiji", "com.google.android.wearable.overlay.common.baiji",
"com.google.android.wearable.overlay.helium.baiji", "com.google.android.wearable.overlay.helium.baiji",
"com.google.android.wearable.overlay.home.baiji", "com.google.android.wearable.overlay.home.baiji",
"com.google.android.wearable.overlay.home.baiji",
"com.google.android.wearable.overlay.home.baiji.tiles", "com.google.android.wearable.overlay.home.baiji.tiles",
"com.gotokeep.keep", "com.gotokeep.keep",
"com.onetrack.watch", "com.onetrack.watch",

View File

@ -22,6 +22,7 @@
"remove_installed_apps_failed": "Remove Installed Apps Failed", "remove_installed_apps_failed": "Remove Installed Apps Failed",
"removing": "Removing", "removing": "Removing",
"installing": "Installing", "installing": "Installing",
"restoring": "Restoring",
"remove_selected_user_apps": "Removed Selected User Apps", "remove_selected_user_apps": "Removed Selected User Apps",
"install_compatible_apps_header": "Install Compatible Apps", "install_compatible_apps_header": "Install Compatible Apps",
"simple_weather_activated_on_watch": "simpleWeather Activated On Watch", "simple_weather_activated_on_watch": "simpleWeather Activated On Watch",

View File

@ -4,7 +4,9 @@ const shellExec = require('shell-exec')
const Language = require("@shypes/language-translator"); const Language = require("@shypes/language-translator");
const inquirer = require('../lib/inquirer'); const inquirer = require('../lib/inquirer');
const common = require('./common') const common = require('./common')
const chalk = require('chalk');
const globalVariables = require('../lib/globalVars');
const { removeAppsList } = require('../lib/inquirer');
if (process.platform === 'win32' || process.platform === 'win64') { if (process.platform === 'win32' || process.platform === 'win64') {
adbRun = 'adb' adbRun = 'adb'
@ -13,10 +15,6 @@ if (process.platform === 'win32' || process.platform === 'win64') {
} }
module.exports = { module.exports = {
getListOfAPk: () => {
const result = gfin('./data/apps', matchFiletypes = ["apk"], checkSubDirectories = false)
return result
},
installApk: async (element) => { installApk: async (element) => {
result = await shellExec(adbRun + ' install -r ' + element).then(async function (result) { result = await shellExec(adbRun + ' install -r ' + element).then(async function (result) {
if (result.stderr != '') { if (result.stderr != '') {
@ -52,8 +50,46 @@ module.exports = {
}, },
removeApk: async (package) => { removeApk: async (package) => {
result = await shellExec(adbRun + ' uninstall ' + package) result = await shellExec(adbRun + ' uninstall ' + package)
console.log(package + ' - ' + result.stdout); if (result.stderr != '') {
logger.info(package + ' - ' + result.stdout); logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Removing ' + package + ' - ' + result.stdout);
console.log('Removing ' + package + ' - ' + result.stdout);
}
},
removeXiaomiApk: async (package) => {
result = await shellExec(adbRun + ' shell pm uninstall -k --user 0 ' + package)
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Removing ' + package + ' - ' + result.stdout);
console.log('Removing ' + package + ' - ' + result.stdout);
}
},
restoreXiaomiApk: async (package) => {
result = await shellExec(adbRun + ' shell cmd package install-existing ' + package)
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Removing ' + package + ' - ' + result.stdout);
console.log('Removing ' + package + ' - ' + result.stdout);
}
},
restoreAnyApk: async (package) => {
result = await shellExec(adbRun + ' shell cmd package install-existing ' + package.restoreAnyApp)
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else if (result.stdout.includes('doesn\'t exist')) {
logger.info(result.stdout);
console.log(chalk.redBright(result.stdout));
} else {
logger.info('Restoring ' + package.restoreAnyApp + ' - ' + result.stdout);
console.log('Restoring ' + package.restoreAnyApp + ' - ' + result.stdout);
}
}, },
getInstalledPacakges: async () => { getInstalledPacakges: async () => {
result = await shellExec(adbRun + ' shell pm list packages -3') result = await shellExec(adbRun + ' shell pm list packages -3')
@ -82,4 +118,57 @@ module.exports = {
return value return value
} }
}, },
killAdbServer: async () => {
let result = await shellExec(adbRun + ' kill-server')
logger.info('Restarting ADB')
logger.info(result.stdout)
},
watchConnection: async (value) => {
if (value.connection === "usb") {
await module.exports.killAdbServer()
result = await shellExec(adbRun + ' devices')
console.log(result.stdout)
if (result.stdout.includes('device', 15)) {
console.log(chalk.green('MiWatch Connected via USB'))
await common.pause(3000)
logger.info("MiWatch connected")
globalVariables.localUSB = "X"
return true
} else {
console.log(chalk.red('MiWatch not found'))
logger.info("MiWatch not found")
await common.pause(2000)
console.log(chalk.white('Try Again'))
await common.pause(1000)
return false
}
}
if (value.connection === "wifi") {
const value = await inquirer.connectWifi();
await module.exports.killAdbServer()
result = await shellExec(adbRun + ' connect ' + value.connectWifi)
logger.info("Connect Wifi Result " + result.stdout)
if (result.stdout.includes('already connected') || result.stdout.includes('connected to ')) {
console.log(chalk.green('MiWatch Connected'))
globalVariables.localUSB = ""
globalVariables.miWatchIpaddress = value.connectWifi
await common.pause(3000)
logger.info("Connect Wifi Complete")
return true
} else {
if (result.stdout.includes('failed to authenticate')) {
console.log(chalk.redBright('MiWatch not authenticated'))
logger.info('MiWatch not authenticated')
return false
} else {
console.log(chalk.red(result.stdout))
logger.info(result.stdout)
}
await common.pause(2000)
console.log(chalk.white('Try Again'))
await common.pause(1000)
return false
}
}
}
}; };

View File

@ -1,7 +1,8 @@
const fs = require('fs'); const fs = require('fs');
const path = require('path'); const path = require('path');
const tiny = require("@peterpanhihi/tiny"); const tiny = require("@peterpanhihi/tiny");
const { resolve } = require('path'); const getFilesIn = require('get-files-in')
module.exports = { module.exports = {
getCurrentDirectoryBase: () => { getCurrentDirectoryBase: () => {
@ -39,5 +40,9 @@ module.exports = {
} }
resolve(x / y); resolve(x / y);
}).catch(err => NaN) }).catch(err => NaN)
} },
getListOfAPk: (path) => {
const result = getFilesIn(path, matchFiletypes = ["apk"], checkSubDirectories = false)
return result
},
} }

View File

@ -1,11 +1,8 @@
const chalk = require('chalk'); const chalk = require('chalk');
const common = require('../lib/common'); const common = require('../lib/common');
const inquirer = require('../lib/inquirer'); const inquirer = require('../lib/inquirer');
const shellExec = require('shell-exec')
const files = require('../lib/files') const files = require('../lib/files')
const getFilesIn = require('get-files-in') const logger = require('perfect-logger');
let logger = require('perfect-logger');
const globalVariables = require('../lib/globalVars');
const Language = require("@shypes/language-translator"); const Language = require("@shypes/language-translator");
const adb = require('../lib/adb'); const adb = require('../lib/adb');
@ -41,7 +38,7 @@ module.exports = {
module.exports.mainMenu() module.exports.mainMenu()
}, },
compatibleApps: async () => { installCompatibleApps: async () => {
logger.info(await Language.get('install_compatible_apps_header')) logger.info(await Language.get('install_compatible_apps_header'))
common.header(await Language.get('install_compatible_apps_header')) common.header(await Language.get('install_compatible_apps_header'))
@ -59,12 +56,12 @@ module.exports = {
} }
} }
const apkList = await adb.getListOfAPk() const apkList = await files.getListOfAPk('./data/apps')
for (let element of apkList) { for (let package of apkList) {
console.log(await Language.get('installing') + ' ' + element) console.log(await Language.get('installing') + ' ' + package)
logger.info(await Language.get('installing') + ' ' + element) logger.info(await Language.get('installing') + ' ' + package)
await adb.installApk(element) await adb.installApk(package)
} }
console.log(chalk.green(await Language.get('compatible_apps_installed'))) console.log(chalk.green(await Language.get('compatible_apps_installed')))
logger.info(await Language.get('compatible_apps_installed')) logger.info(await Language.get('compatible_apps_installed'))
@ -75,17 +72,8 @@ module.exports = {
logger.info("Remove Apps") logger.info("Remove Apps")
common.header('Remove Apps') common.header('Remove Apps')
const value = await inquirer.removeAppsList(); const value = await inquirer.removeAppsList();
for (let element of value.removeAppsList) { for (let package of value.removeAppsList) {
// await shellExec(adbRun + ' shell pm disable-user --0 ' + element).then(function (result) { await adb.removeXiaomiApk(package)
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')) console.log(chalk.green('Removal Complete'))
await common.pause(2000) await common.pause(2000)
@ -96,16 +84,8 @@ module.exports = {
logger.info("Restore Apps") logger.info("Restore Apps")
common.header('Restore Apps') common.header('Restore Apps')
const value = await inquirer.removeAppsList(); const value = await inquirer.removeAppsList();
for (let element of value.removeAppsList) { for (let package of value.removeAppsList) {
await shellExec(adbRun + ' shell cmd package install-existing ' + element).then(function (result) { await adb.restoreXiaomiApk(package)
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright('Error - Device not authorised'));
} else {
logger.info('Restoring ' + element + ' - ' + result.stdout);
console.log('Restoring ' + element + ' - ' + result.stdout);
}
});
} }
console.log(chalk.green('Restore Complete')) console.log(chalk.green('Restore Complete'))
await common.pause(2000) await common.pause(2000)
@ -116,74 +96,19 @@ module.exports = {
logger.info("Connect to watch") logger.info("Connect to watch")
common.header('Connect to watch') common.header('Connect to watch')
const value = await inquirer.connectionType() const value = await inquirer.connectionType()
if (value.connection === "usb") { connected = await adb.watchConnection(value)
await shellExec(adbRun + ' kill-server').then(async function (result) { if (connected != true) {
logger.info('Restarting ADB')
logger.info(result.stdout)
})
await shellExec(adbRun + ' devices').then(async function (result) {
console.log(result.stdout)
if (result.stdout.includes('device', 15)) {
console.log(chalk.green('MiWatch Connected via USB'))
await common.pause(3000)
logger.info("MiWatch connected")
globalVariables.localUSB = "X"
module.exports.mainMenu()
} else {
console.log(chalk.red('MiWatch not found'))
logger.info("MiWatch not found")
await common.pause(2000)
console.log(chalk.white('Try Again'))
await common.pause(1000)
module.exports.connectWatch() module.exports.connectWatch()
} } else {
})
}
if (value.connection === "wifi") {
const value = await inquirer.connectWifi();
await shellExec(adbRun + ' kill-server').then(async function (result) {
logger.info('Restarting ADB')
logger.info(result.stdout)
})
await shellExec(adbRun + ' connect ' + value.connectWifi).then(async function (result) {
logger.info("Connect Wifi Result " + result.stdout)
if (result.stdout.includes('already connected') || result.stdout.includes('connected to ')) {
console.log(chalk.green('MiWatch Connected'))
globalVariables.localUSB = ""
globalVariables.miWatchIpaddress = value.connectWifi
await common.pause(3000)
logger.info("Connect Wifi Complete")
module.exports.mainMenu() module.exports.mainMenu()
} else {
if (result.stdout.includes('failed to authenticate')) {
console.log(chalk.redBright('MiWatch not authenticated'))
logger.info('MiWatch not authenticated')
} else {
console.log(chalk.red(result.stdout))
logger.info(result.stdout)
}
await common.pause(2000)
console.log(chalk.white('Try Again'))
await common.pause(1000)
module.exports.connectWatch()
}
}).catch()
} }
}, },
oneClick: async () => { oneClick: async () => {
logger.info("1-Click Karl0ss Klean") logger.info("1-Click Karl0ss Klean")
common.header('1-Click Karl0ss Klean') common.header('1-Click Karl0ss Klean')
const removalPackagesList = files.loadPackageList() const removalPackagesList = files.loadPackageList()
for (let element of removalPackagesList.apps) { for (let package of removalPackagesList.apps) {
await shellExec(adbRun + ' shell pm uninstall -k --user 0 ' + element).then(function (result) { await adb.removeXiaomiApk(package)
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')) console.log(chalk.green('Removal Complete'))
await common.pause(2000) await common.pause(2000)
@ -193,33 +118,24 @@ module.exports = {
await common.clearApkFolder() await common.clearApkFolder()
const compatibleApps = await common.getCompatibleAppsList() const compatibleApps = await common.getCompatibleAppsList()
console.log(chalk.green('Download Compatible APKS'))
for (const element of compatibleApps) { for (const package of compatibleApps) {
if (element.Klean === "X") { if (package.Klean === "X") {
try { try {
logger.info('Downloading Latest ' + element.name + ' Complete') newPacakgeName = package.name.replace(/\s/g, '');
newName = element.name.replace(/\s/g, ''); await common.downloadFile(package.url, './data/apps/' + newPacakgeName + '.apk')
await common.downloadFile(element.url, './data/apps/' + newName + '.apk') logger.info('Downloading Latest ' + package.name + ' Complete')
logger.info('Downloading Latest ' + element.name + ' Complete') console.log('Downloading Latest ' + package.name + ' Complete')
} catch (error) { } catch (error) {
logger.info('Downloading Latest ' + element.name + ' FAILED') logger.info('Downloading Latest ' + package.name + ' FAILED')
} }
} }
} }
const apkList = await getFilesIn('./data/apps', matchFiletypes = ['apk'], checkSubDirectories = false) const apkList = await files.getListOfAPk('./data/apps')
console.log(chalk.green('Install Apks'))
for (let element of apkList) { for (let element of apkList) {
console.log('Installing ' + element) await adb.installApk(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')) console.log(chalk.green('Compatible Apps Installed'))
logger.info('Compatible Apps Installed') logger.info('Compatible Apps Installed')
@ -230,15 +146,7 @@ module.exports = {
logger.info("Restore Any App") logger.info("Restore Any App")
common.header('Restore Any App') common.header('Restore Any App')
const value = await inquirer.restoreAnyApp(); const value = await inquirer.restoreAnyApp();
await shellExec(adbRun + ' shell cmd package install-existing ' + value.restoreAnyApp).then(function (result) { await adb.restoreAnyApk(value)
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')) console.log(chalk.green('Restore Complete'))
await common.pause(2000) await common.pause(2000)
logger.info("App Restore Complete") logger.info("App Restore Complete")
@ -248,23 +156,14 @@ module.exports = {
logger.info("Batch Install Apks") logger.info("Batch Install Apks")
common.header('Batch Install Apks') common.header('Batch Install Apks')
let apkList = await getFilesIn('./my_apk/', matchFiletypes = ['apk'], checkSubDirectories = false) let apkList = await files.getListOfAPk('./my_apk/')
await files.renameLocalApk(apkList) await files.renameLocalApk(apkList)
apkList = await files.getListOfAPk('./my_apk/')
apkList = await getFilesIn('./my_apk/', matchFiletypes = ['apk'], checkSubDirectories = false)
for (let element of apkList) { for (let element of apkList) {
console.log('Installing ' + element) console.log('Installing ' + element)
logger.info('Installing ' + element) logger.info('Installing ' + element)
await shellExec(adbRun + ' install -r ' + element).then(async function (result) { await adb.installApk(element)
if (result.stderr != '') {
logger.info('Error ' + result.stderr);
console.log(chalk.redBright(result.stderr));
}
console.log(element + ' - ' + result.stdout);
logger.info(element + ' - ' + result.stdout);
});
} }
console.log(chalk.green('Batch Install Apks Completed')) console.log(chalk.green('Batch Install Apks Completed'))
logger.info('Batch Install Apks Completed') logger.info('Batch Install Apks Completed')
@ -288,7 +187,7 @@ module.exports = {
module.exports.restoreApps() module.exports.restoreApps()
break; break;
case 'install compatible apps': case 'install compatible apps':
module.exports.compatibleApps() module.exports.installCompatibleApps()
break; break;
case 'batch remove installed apps': case 'batch remove installed apps':
module.exports.removeCompatibleApps() module.exports.removeCompatibleApps()