kernelsu-alt
v3.1.1
Published
Library for KernelSU and KernelSU-Next module WebUI
Downloads
421
Readme
Library for KernelSU's module WebUI
Install
npm i kernelsu-altAPI
exec
Spawns a root shell and runs a command within that shell, passing the stdout and stderr to a Promise when complete.
command<string>The command to run, with space-separated arguments.options<Object>cwd- Current working directory of the child processenv- Environment key-value pairs
import { exec } from 'kernelsu-alt';
const { errno, stdout, stderr } = await exec('ls -l', { cwd: '/tmp' });
if (errno === 0) {
// success
console.log(stdout);
}spawn
Spawns a new process using the given command in root shell, with command-line arguments in args. If omitted, args defaults to an empty array.
Returns a ChildProcess, Instances of the ChildProcess represent spawned child processes.
command<string>The command to run.args<string[]>List of string arguments.options<Object>:cwd<string>- Current working directory of the child processenv<Object>- Environment key-value pairs
Example of running ls -lh /data, capturing stdout, stderr, and the exit code:
import { spawn } from 'kernelsu-alt';
const ls = spawn('ls', ['-lh', '/data']);
ls.stdout.on('data', (data) => {
console.log(`stdout: ${data}`);
});
ls.stderr.on('data', (data) => {
console.log(`stderr: ${data}`);
});
ls.on('exit', (code) => {
console.log(`child process exited with code ${code}`);
});ChildProcess
Event 'exit'
code<number>The exit code if the child exited on its own.
The 'exit' event is emitted after the child process ends. If the process exited, code is the final exit code of the process, otherwise null
Event 'error'
err<Error>The error.
The 'error' event is emitted whenever:
- The process could not be spawned.
- The process could not be killed.
stdout
A Readable Stream that represents the child process's stdout.
const subprocess = spawn('ls');
subprocess.stdout.on('data', (data) => {
console.log(`Received chunk ${data}`);
});stderr
A Readable Stream that represents the child process's stderr.
fullScreen
Request the WebView enter/exit full screen.
import { fullScreen } from 'kernelsu-alt';
fullScreen(true);enableEdgeToEdge
Request the WebView to set padding to 0 or system bar insets
- tips: this is disabled by default but if you request resource from
internal/insets.css, this will be enabled automatically. - To get insets value and enable this automatically, you can
- add
@import "https://mui.kernelsu.org/internal/insets.css";in css OR - add
<link rel="stylesheet" type="text/css" href="/internal/insets.css" />in html.
- add
- Note:
enableInsetsis renamed toenableEdgeToEdgesince KernelSU 32265. Old api is kept and marked as deprecated for compatibility, there is no plan to remove it currently.
import { enableEdgeToEdge } from 'kernelsu-alt';
const result = await enableEdgeToEdge(true);
if (!result) {
console.log('Function not implemented');
}toast
Show a toast message.
import { toast } from 'kernelsu-alt';
toast('Hello, world!');listPackages
Lists installed packages on the Android system.
type<string>The type of packages to list. Can be one of'user','system', or'all'. Defaults to'all'.
Returns a Promise<string[]> which resolves to an array of package names.
import { listPackages } from 'kernelsu-alt';
// Get all installed packages
const allPackages = await listPackages();
console.log(allPackages);
// Get only user-installed packages
const userPackages = await listPackages('user');
console.log(userPackages);getPackagesInfo
Retrieves detailed information for one or more packages.
pkg<string|string[]>A single package name or an array of package names.
Returns a Promise<PackagesInfo|PackagesInfo[]> which resolves to:
- A single package information object if a single package name is provided.
- An array of package information objects if an array of package names is provided.
The PackagesInfo object has the following structure:
packageName<string>- Package name of the application.versionName<string>- Version of the application.versionCode<number>- Version code of the application.appLabel<string>- Display name of the application.isSystem<boolean>- Whether the application is a system app.uid<number>- UID of the application.
import { getPackagesInfo } from 'kernelsu-alt';
// Get info for a single package
const info = await getPackagesInfo('com.android.settings');
console.log(info);
// Get info for multiple packages
const infos = await getPackagesInfo(['com.android.settings', 'com.android.shell']);
console.log(infos);