diff --git a/js/README.md b/js/README.md index 4af3a7185863..36add3db9be4 100644 --- a/js/README.md +++ b/js/README.md @@ -109,3 +109,12 @@ Show a toast message. import { toast } from 'kernelsu'; toast('Hello, world!'); ``` + +### getModuleId + +Get Module path. +```javascript +import { moduleDir } from 'kernelsu'; +// print moduleId in console +console.log(moduleDir()); +``` \ No newline at end of file diff --git a/js/index.d.ts b/js/index.d.ts index b65248e378f7..cfcf064fc6ba 100644 --- a/js/index.d.ts +++ b/js/index.d.ts @@ -37,9 +37,12 @@ declare function fullScreen(isFullScreen: boolean); declare function toast(message: string); +declare function moduleDir(): string; + export { exec, spawn, fullScreen, - toast + toast, + moduleDir } diff --git a/js/index.js b/js/index.js index 4b64e9c4c455..9e4d9728bb69 100644 --- a/js/index.js +++ b/js/index.js @@ -113,3 +113,7 @@ export function fullScreen(isFullScreen) { export function toast(message) { ksu.toast(message); } + +export function moduleDir() { + return ksu.moduleDir(); +} diff --git a/js/package.json b/js/package.json index 02b350f33c79..12002a05328e 100644 --- a/js/package.json +++ b/js/package.json @@ -1,6 +1,6 @@ { "name": "kernelsu", - "version": "1.0.6", + "version": "1.0.7", "description": "Library for KernelSU's module WebUI", "main": "index.js", "types": "index.d.ts", diff --git a/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebUIActivity.kt b/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebUIActivity.kt index eccb002a1688..93e1154d8bda 100644 --- a/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebUIActivity.kt +++ b/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebUIActivity.kt @@ -29,7 +29,8 @@ class WebUIActivity : ComponentActivity() { val prefs = getSharedPreferences("settings", Context.MODE_PRIVATE) WebView.setWebContentsDebuggingEnabled(prefs.getBoolean("enable_web_debugging", false)) - val webRoot = File("/data/adb/modules/${moduleId}/webroot") + val moduleDir = "/data/adb/modules/${moduleId}" + val webRoot = File("${moduleDir}/webroot") val rootShell = createRootShell(true).also { this.rootShell = it } val webViewAssetLoader = WebViewAssetLoader.Builder() .setDomain("mui.kernelsu.org") @@ -52,7 +53,7 @@ class WebUIActivity : ComponentActivity() { settings.javaScriptEnabled = true settings.domStorageEnabled = true settings.allowFileAccess = false - webviewInterface = WebViewInterface(this@WebUIActivity, this) + webviewInterface = WebViewInterface(this@WebUIActivity, this,moduleDir) addJavascriptInterface(webviewInterface, "ksu") setWebViewClient(webViewClient) loadUrl("https://mui.kernelsu.org/index.html") diff --git a/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebViewInterface.kt b/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebViewInterface.kt index 4b6a3c8f755d..4e0bab9bdc1c 100644 --- a/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebViewInterface.kt +++ b/manager/app/src/main/java/me/weishu/kernelsu/ui/webui/WebViewInterface.kt @@ -20,7 +20,7 @@ import org.json.JSONArray import org.json.JSONObject import java.util.concurrent.CompletableFuture -class WebViewInterface(val context: Context, private val webView: WebView) { +class WebViewInterface(val context: Context, private val webView: WebView, private val modDir: String) { @JavascriptInterface fun exec(cmd: String): String { @@ -170,6 +170,11 @@ class WebViewInterface(val context: Context, private val webView: WebView) { } } + @JavascriptInterface + fun moduleDir(): String { + return modDir; + } + } fun hideSystemUI(window: Window) {