Compare commits
No commits in common. "631056030e5c98aea33da5395c5889fec2739106" and "3a9ac9f73fd82cc3d335960f87e16656a47b72eb" have entirely different histories.
631056030e
...
3a9ac9f73f
1
.bashrc
Normal file
|
@ -0,0 +1 @@
|
|||
|
8
.gitignore
vendored
|
@ -1,13 +1,5 @@
|
|||
*.apk
|
||||
*.apk.install-log
|
||||
apk/ToyKey.keystore
|
||||
apk/obj
|
||||
apk/obj/*
|
||||
apk/bin/*
|
||||
apk/result
|
||||
apk/result/
|
||||
apk/result/*
|
||||
apk/bin/!.gitkeep
|
||||
/example.app.apk
|
||||
docker-compose-build.log
|
||||
/Makefile.apps
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
FROM archlinux:latest
|
||||
|
||||
RUN pacman -Syu --noconfirm
|
||||
RUN pacman -S --noconfirm coreutils bash shadow make unzip zip jdk11-openjdk wget
|
||||
RUN pacman -S --noconfirm coreutils bash shadow make unzip jdk11-openjdk wget
|
||||
ENV ANDROID_SDK_ROOT="/opt/android"
|
||||
ENV BUILD_TOOLS_LATEST="$ANDROID_SDK_ROOT/cmdline-tools/latest"
|
||||
RUN BUILD_TOOLS="$(realpath -m "$BUILD_TOOLS_LATEST/..")";\
|
||||
|
@ -19,11 +19,9 @@ ENV JAVA_HOME="/usr/lib/jvm/java-11-openjdk/"
|
|||
#ENTRYPOINT bash -c 'sleep 10000'
|
||||
ENV LIBRARY_PATH="$LIBRARY_PATH:$BUILD_TOOLS_LATEST/lib"
|
||||
ARG YESACCEPT=n
|
||||
RUN test "$YESACCEPT" = "y" || { printf "\033[31;1;4m%s\n%s\033[0m " "FAILED TO BUILD CONTAINER: You did not ACCEPT THE UPSTREAM LICENSE" " -> export YESACCEPT=y" >&2; exit 1; }
|
||||
RUN echo you selected to accept the licenses/TOS
|
||||
RUN echo "$YESACCEPT" | sdkmanager --install "build-tools;33.0.2"
|
||||
RUN echo "$YESACCEPT" | sdkmanager --install "platforms;android-33"
|
||||
RUN echo "$YESACCEPT" | sdkmanager --install "ndk;28.0.12433566"
|
||||
#RUN apk add setpriv
|
||||
COPY entrypoint.sh /entrypoint.sh
|
||||
RUN chown 0:0 /entrypoint.sh
|
||||
|
|
131
Makefile
|
@ -1,123 +1,36 @@
|
|||
|
||||
# this includes explicit rules
|
||||
|
||||
|
||||
include Makefile.apps
|
||||
Makefile.apps: Makefile apps
|
||||
@(\
|
||||
cd apps;\
|
||||
for APP in */;\
|
||||
do \
|
||||
test -d "$$APP" || continue;\
|
||||
APP="$${APP%/}";\
|
||||
MFA="\
|
||||
apps/$$APP/app.apk: docker-compose-build.log\n\
|
||||
docker compose run --rm compile $$APP\n\
|
||||
build-$$APP: apps/$$APP/app.apk\n\
|
||||
true\n\
|
||||
apps/$$APP/app.apk.install-log: apps/$$APP/app.apk\n\
|
||||
adb install -r $$< > \$$@ || rm \$$@ \n\
|
||||
install-$$APP: apps/$$APP/app.apk.install-log\n\
|
||||
true\n\
|
||||
run-$$APP: apps/$$APP/app.apk.install-log\n\
|
||||
adb shell am start -n app.example/.ExampleApp\n\
|
||||
";\
|
||||
done;\
|
||||
printf "$$MFA" \
|
||||
) > "$@"
|
||||
all: build install
|
||||
|
||||
apps:
|
||||
mkdir "$@"
|
||||
build:
|
||||
docker-compose run compile
|
||||
|
||||
install: $(shell for APP in apps/*/; do test -d "$$APP" || continue; echo "$$APP""app.apk.install-log"; done)
|
||||
force-install reinstall:
|
||||
for APP in apps/*/; do rm -f "$$APP""app.apk.install-log" 2>/dev/null; done; $(MAKE) install
|
||||
run: $(shell cd apps/; for APP in */; do test -d "$$APP" || continue; echo "run-$${APP%/}"; done)
|
||||
install:
|
||||
adb install -r ./apk/example.app.apk
|
||||
|
||||
#newer :=$(shell test Makefile.apps -nt Makefile -a Makefile.apps -nt apps && printf Y)
|
||||
#ifndef newer
|
||||
#Makefile.apps: FORCE
|
||||
# printf 'inmf: ; echo $$@\n' > $@
|
||||
#FORCE:
|
||||
#endif
|
||||
#include Makefile.apps
|
||||
.PHONY: clean-all
|
||||
clean-all: clean-docker clean-apk
|
||||
|
||||
|
||||
#include depend
|
||||
#depend: Makefile
|
||||
# printf 'independ: ; echo super\n' >> $@
|
||||
#newer :=$(shell echo a)
|
||||
#ifdef($(newer))
|
||||
#include depend
|
||||
#endif
|
||||
.PHONY: clean-docker
|
||||
clean-docker:
|
||||
rm docker-compose-build.log || true
|
||||
docker-compose down --remove-orphans --rmi all
|
||||
|
||||
|
||||
#APPDIRS = $(wildcard apps/*/)
|
||||
##APPDIRS := $(APPDIRS) apps/newapp/
|
||||
#TESTFILES = $(patsubst %, %test ,$(APPDIRS))
|
||||
#test:
|
||||
# echo $(wildcard apps/*/)
|
||||
# echo $(APPDIRS)
|
||||
.PHONY: clean-apk
|
||||
clean-apk:
|
||||
cd apk && $(MAKE) clean
|
||||
|
||||
##a b c:
|
||||
## echo $@
|
||||
|
||||
#echo-testfiles:
|
||||
# echo $(TESTFILES)
|
||||
#
|
||||
#$(TESTFILES) :
|
||||
# echo "$@"
|
||||
#
|
||||
#$(APPDIRS) :
|
||||
# echo "$@"
|
||||
#
|
||||
###.PHONY: all
|
||||
###all: install-all
|
||||
###
|
||||
###.PHONY: run-webview
|
||||
###run-webview: install-webview
|
||||
### adb shell am start -n app.example/.ExampleApp
|
||||
###
|
||||
###.PHONY: build-all
|
||||
###build-all: build-webview build-native
|
||||
###
|
||||
###
|
||||
###.PHONY: build-webview
|
||||
###build-webview: docker-compose-build.log
|
||||
### docker-compose run --rm compile webview
|
||||
### ln -sf apk/webview/result/example.app.apk ./; test -e ./example.app.apk || rm ./example.app.apk
|
||||
###
|
||||
###.PHONY: build-native
|
||||
###build-native: docker-compose-build.log
|
||||
### docker-compose run --rm compile native
|
||||
### #ln -sf apk/native/result/example.app.apk ./; test -e ./example.app.apk || rm ./example.app.apk
|
||||
###
|
||||
###.PHONY: install-all
|
||||
###install-all: install-webview install-native
|
||||
###
|
||||
###.PHONY: install-webview
|
||||
###install-webview: build-webview
|
||||
### adb install -r ./example.app.apk
|
||||
###
|
||||
###.PHONY: install-native
|
||||
###install-native: build-native
|
||||
### true
|
||||
### #adb install -r ./example.app.apk
|
||||
###
|
||||
###.PHONY: clean-all
|
||||
###clean-all: clean-docker clean-apk
|
||||
###
|
||||
###.PHONY: clean-docker
|
||||
###clean-docker:
|
||||
### rm docker-compose-build.log || true
|
||||
### docker-compose down --remove-orphans --rmi all
|
||||
###
|
||||
###.PHONY: clean-apk
|
||||
###clean-apk:
|
||||
### cd apk && $(MAKE) clean
|
||||
###
|
||||
###
|
||||
docker-compose-build.log: Dockerfile compose.yml
|
||||
|
||||
apk: apk/app.apk
|
||||
true
|
||||
|
||||
apk/app.apk: docker-compose-build.log
|
||||
docker-compose run --rm compile
|
||||
|
||||
docker-compose-build.log: Dockerfile docker-compose.yml
|
||||
docker-compose down --remove-orphans --rmi all
|
||||
BUILDKIT_PROGRESS=plain docker-compose build | tee docker-compose-build.log
|
||||
|
||||
|
|
21
apk/AndroidManifest.xml
Normal file
|
@ -0,0 +1,21 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
package="app.example"
|
||||
android:versionCode="1"
|
||||
android:versionName="1.0">
|
||||
<uses-sdk android:minSdkVersion="30"
|
||||
android:targetSdkVersion="33"/>
|
||||
<uses-permission android:name="android.permission.INTERNET">
|
||||
</uses-permission>
|
||||
<!-- android:maxSdkVersion="integer" /> -->
|
||||
<application android:label="@string/app_name" android:icon="@drawable/ic_launcher">
|
||||
<activity android:name="app.example.ExampleApp"
|
||||
android:exported="true"
|
||||
android:label="@string/app_name">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
<category android:name="android.intent.category.LAUNCHER" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
</application>
|
||||
</manifest>
|
|
@ -14,35 +14,29 @@ all: build
|
|||
.PHONY : deploy
|
||||
.PHONY : clean
|
||||
|
||||
build : ./result/example.app.apk
|
||||
mv ./result/example.app.apk app.apk
|
||||
true
|
||||
build : ./bin/example.app.apk
|
||||
ln -sf ./bin/example.app.apk ./example.app.apk
|
||||
|
||||
env:
|
||||
set > set ; env > env
|
||||
./result/example.app.apk : ./result/signed.apk
|
||||
./bin/example.app.apk : ./bin/signed.apk
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/zipalign -v -f 4 $< $@
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/apksigner sign --ks ToyKey.keystore --key-pass pass:armena --ks-pass pass:armena $@
|
||||
|
||||
./result/signed.apk : ./result/unsigned.apk ./ToyKey.keystore ./result
|
||||
./bin/signed.apk : ./bin/unsigned.apk ./ToyKey.keystore
|
||||
jarsigner -verbose -keystore ./ToyKey.keystore -storepass armena -keypass armena -signedjar $@ $< helljniKey
|
||||
|
||||
./result:
|
||||
mkdir -p "$@"
|
||||
|
||||
./result/unsigned.apk : ./bin/classes.dex ./result
|
||||
./bin/unsigned.apk : ./bin/classes.dex
|
||||
rm -rvf "$@"
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/aapt package -v -u -f -M ./AndroidManifest.xml -S ./res \
|
||||
-I $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar -A ./assets -F $@ ./bin
|
||||
-I $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar -F $@ ./bin
|
||||
|
||||
./bin/classes.dex : ./obj/app/example/ExampleApp.class ./obj/app/example/ExampleApp$$1.class
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/d8 ./obj/app/example/*.class --lib $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar --output bin
|
||||
./bin/classes.dex : ./obj/app/example/ExampleApp.class
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/d8 $(shell find obj -name '*.class') --lib $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar --output bin
|
||||
|
||||
./src/app/example/R.java : $(shell find ./res -type f)
|
||||
$(ANDROID_HOME)/build-tools/$(ANDROID_VERSION)/aapt package -v -f -m -S ./res -J ./src -M ./AndroidManifest.xml \
|
||||
-I $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar
|
||||
|
||||
./obj/app/example/ExampleApp.class : ./src/app/example/ExampleApp.java ./src/app/example/R.java
|
||||
./obj/app/example/ExampleApp.class : ./src/app/example/ExampleApp.java ./src/app/example/R.java
|
||||
javac -d ./obj -classpath $(ANDROID_HOME)/platforms/$(PLATFORM)/android.jar -sourcepath ./src $<
|
||||
|
||||
./ToyKey.keystore :
|
||||
|
@ -50,4 +44,4 @@ env:
|
|||
-storepass armena -keypass armena -alias helljniKey -keyalg RSA -v
|
||||
|
||||
clean:
|
||||
rm -f ./bin/* ./lib/arm64-v8a/* ./result/*
|
||||
rm -f ./bin/* ./lib/arm64-v8a/*
|
0
apk/bin/.gitkeep
Normal file
1
apk/example.app.apk
Symbolic link
|
@ -0,0 +1 @@
|
|||
./bin/example.app.apk
|
Before Width: | Height: | Size: 9.2 KiB After Width: | Height: | Size: 9.2 KiB |
Before Width: | Height: | Size: 2.7 KiB After Width: | Height: | Size: 2.7 KiB |
Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 5.1 KiB |
Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 14 KiB |
33
apk/src/app/example/ExampleApp.java
Normal file
|
@ -0,0 +1,33 @@
|
|||
package app.example;
|
||||
|
||||
import android.util.Log;
|
||||
import android.widget.TextView;
|
||||
import android.app.Activity;
|
||||
import android.os.Bundle;
|
||||
import android.text.method.ScrollingMovementMethod;
|
||||
import android.view.MenuItem;
|
||||
import android.view.*;
|
||||
import android.widget.*;
|
||||
import android.view.ViewGroup.*;
|
||||
|
||||
public class ExampleApp extends Activity {
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
// creating LinearLayout
|
||||
LinearLayout linLayout = new LinearLayout(this);
|
||||
// specifying vertical orientation
|
||||
linLayout.setOrientation(LinearLayout.VERTICAL);
|
||||
// creating LayoutParams
|
||||
LayoutParams linLayoutParam = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
|
||||
// set LinearLayout as a root element of the screen
|
||||
setContentView(linLayout, linLayoutParam);
|
||||
|
||||
LayoutParams lpView = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
|
||||
|
||||
TextView tv = new TextView(this);
|
||||
tv.setText("SUPERVIEalexW");
|
||||
tv.setLayoutParams(lpView);
|
||||
linLayout.addView(tv);
|
||||
}
|
||||
}
|
9
apps/webview/.gitignore
vendored
|
@ -1,9 +0,0 @@
|
|||
/ToyKey.keystore
|
||||
/obj
|
||||
/obj/*
|
||||
/bin/*
|
||||
/bin/!.gitkeep
|
||||
/result
|
||||
/result/
|
||||
/result/*
|
||||
/example.app.apk
|
|
@ -1,38 +0,0 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
package="app.example"
|
||||
android:versionCode="1"
|
||||
android:versionName="1.0">
|
||||
<uses-sdk android:minSdkVersion="30"
|
||||
android:targetSdkVersion="33"/>
|
||||
<uses-permission android:name="android.permission.INTERNET"/>
|
||||
<uses-permission android:name="android.permission.INTERNET"/>
|
||||
<uses-permission android:name="android.permission.MANAGE_DOCUMENTS"/>
|
||||
<uses-permission android:name="android.permission.MANAGE_MEDIA"/>
|
||||
<uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE"/>
|
||||
<uses-permission android:name="android.permission.POST_NOTIFICATIONS"/>
|
||||
<uses-permission android:name="android.permission.READ_MEDIA_AUDIO"/>
|
||||
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES"/>
|
||||
<uses-permission android:name="android.permission.READ_MEDIA_VIDEO"/>
|
||||
<uses-permission android:name="android.permission.READ_MEDIA_VISUAL_USER_SELECTED"/>
|
||||
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" android:maxSdkVersion="32" />
|
||||
<uses-permission android:name="android.permission.READ_SYNC_SETTINGS"/>
|
||||
<uses-permission android:name="android.permission.VIBRATE"/>
|
||||
<uses-permission android:name="android.permission.WAKE_LOCK"/>
|
||||
<uses-permission android:name="android.permission.WRITE_CALENDAR"/>
|
||||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
||||
<uses-permission android:name="android.permission.WRITE_MEDIA_STORAGE"/>
|
||||
<uses-permission android:name="android.permission.WRITE_SETTINGS"/>
|
||||
<uses-permission android:name="android.permission.WRITE_SYNC_SETTINGS"/>
|
||||
<application android:label="@string/app_name" android:icon="@drawable/ic_launcher">
|
||||
<activity android:name="app.example.ExampleApp"
|
||||
android:exported="true"
|
||||
android:configChanges="orientation|screenSize|keyboardHidden"
|
||||
android:label="@string/app_name">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
<category android:name="android.intent.category.LAUNCHER" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
</application>
|
||||
</manifest>
|
|
@ -1,111 +0,0 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta content="width=device-width,initial-scale=1.0" name="viewport">
|
||||
</head>
|
||||
<script>
|
||||
|
||||
function sleepit(ms) {
|
||||
return new Promise((resolve) => {
|
||||
setTimeout(() => {
|
||||
resolve(1);
|
||||
}, ms);
|
||||
});
|
||||
}
|
||||
function divMessage(html){
|
||||
var div = document.createElement('div');
|
||||
div.innerHTML=html;
|
||||
document.body.appendChild(div);
|
||||
div.scrollIntoView({ behavior: 'smooth'});
|
||||
}
|
||||
|
||||
(async function webviewprogram(){
|
||||
var port;
|
||||
var resolves = [];
|
||||
function setupMessage(){
|
||||
return new Promise((resolve) => {
|
||||
window.addEventListener('message',(e)=>{
|
||||
if(e.data=="init-from-java" && ! port){
|
||||
divMessage('INIT');
|
||||
port = e.ports[0];
|
||||
port.onmessage = function (ee) {
|
||||
divMessage('AAport.onmessage='+ee.data);
|
||||
var response = JSON.parse(ee.data);
|
||||
divMessage('response.resolveIndex'+response.resolveIndex);//AAport.onmessage='+ee.data);
|
||||
var localresolve = resolves[response.resolveIndex];
|
||||
divMessage(typeof localresolve)
|
||||
|
||||
localresolve(response);
|
||||
}
|
||||
resolve()
|
||||
}
|
||||
divMessage('message='+e.data);
|
||||
},true);
|
||||
});
|
||||
}
|
||||
function doLs(path){
|
||||
divMessage('doLs');
|
||||
return new Promise((resolve) => {
|
||||
divMessage('resolves.length'+resolves.length);
|
||||
resolves.push(resolve);
|
||||
divMessage('after push resolves.length'+resolves.length);
|
||||
port.postMessage('{"function":"ls","path":"'+path+'","resolveIndex":"'+(resolves.length-1)+'"}');
|
||||
});
|
||||
}
|
||||
function doCat(file){
|
||||
return new Promise((resolve) => {
|
||||
resolves.push(resolve);
|
||||
port.postMessage('{"function":"cat","resolveIndex":"'+resolves.length+'"}');
|
||||
});
|
||||
}
|
||||
window.addEventListener('load',()=>{
|
||||
divMessage('JAVASCRIPT WORKS');
|
||||
},false);
|
||||
// await sleepit(2000);
|
||||
// divMessage('awaited 2000');
|
||||
// await sleepit(2000);
|
||||
// divMessage('awaited again 2000');
|
||||
await setupMessage();
|
||||
divMessage('setup');
|
||||
async function mapDoLs(path){
|
||||
var reply = await doLs(path);
|
||||
divMessage("reply.result.length"+reply.result.length);
|
||||
reply.result.forEach((file)=>{
|
||||
divMessage(file.name);//reply.result.length"+reply.result.length);
|
||||
//var button
|
||||
button = document.createElement("button");
|
||||
button.addEventListener("click",()=>{
|
||||
if(file.isDirectory)
|
||||
mapDoLs(path+"/"+file.name);
|
||||
},false);
|
||||
//if(file.isDirectory){
|
||||
//{
|
||||
// button = document.createElement("button");
|
||||
// button.addEventListener("click",()=>{
|
||||
// mapDoLs(path+"/"+file.name);
|
||||
// },false);
|
||||
//} else {
|
||||
// button = document.createElement("div");
|
||||
//}
|
||||
////a.href="#";
|
||||
//////a.textContent="asdasdada"
|
||||
button.textContent=file.name+ " " + file.size;
|
||||
document.body.appendChild(button);
|
||||
});
|
||||
}
|
||||
await mapDoLs("/DCIM");
|
||||
divMessage("done");
|
||||
// for(let file of DCIM.result){
|
||||
// divMessage("filename");
|
||||
|
||||
//});
|
||||
})();
|
||||
</script>
|
||||
<a href='https://html5test.co/'>https://html5test.co/</a>
|
||||
<h1> this is html <h1>
|
||||
<h2> this is a h2</h2>
|
||||
<input type=text />
|
||||
<img src='https://wald.alexmahr.de/images/bear.avif'>
|
||||
<img src='https://wald.alexmahr.de/images/delphin.avif'>
|
||||
</html>
|
|
@ -1,179 +0,0 @@
|
|||
package app.example;
|
||||
import android.provider.Settings ;
|
||||
import android.content.Intent;
|
||||
import android.util.Log;
|
||||
import android.util.Base64;
|
||||
import java.util.Objects;
|
||||
import android.app.Activity;
|
||||
import android.os.Bundle;
|
||||
import android.os.CountDownTimer;
|
||||
import android.os.Environment;
|
||||
import android.text.method.ScrollingMovementMethod;
|
||||
import android.view.*;
|
||||
//import android.view.MenuItem;
|
||||
import android.view.ViewGroup.*;
|
||||
import android.widget.*;
|
||||
//import android.widget.Toast;
|
||||
//import android.widget.TextView;
|
||||
import android.webkit.*;
|
||||
import android.net.Uri;
|
||||
import org.json.JSONObject;
|
||||
//import android.webkit.WebView;
|
||||
//import android.webkit.WebMessage;
|
||||
//import android.webkit.WebMessagePort;
|
||||
import java.io.InputStream;
|
||||
import java.io.File;
|
||||
|
||||
public class ExampleApp extends Activity {
|
||||
|
||||
public JSONObject doLs(JSONObject message){
|
||||
try{
|
||||
JSONObject file;
|
||||
File directory = new File(Environment.getExternalStorageDirectory().toString() + message.getString("path"));
|
||||
File[] files = directory.listFiles();
|
||||
for (int i = 0; i < files.length; i++)
|
||||
{
|
||||
try{
|
||||
//Log.d("ALEXINFO","filename"+files[i].getName());
|
||||
file = new JSONObject();
|
||||
file.put("name",files[i].getName());
|
||||
file.put("isFile",files[i].isFile());
|
||||
file.put("isDirectory",files[i].isDirectory());
|
||||
file.put("size",files[i].length());
|
||||
message.accumulate("result",file);
|
||||
} catch (Exception e) {
|
||||
Log.d("Exception EX1","ex1");
|
||||
}
|
||||
}
|
||||
} catch (Exception e) {
|
||||
Log.d("Exception EX2","ex2");
|
||||
}
|
||||
return message;
|
||||
}
|
||||
|
||||
public JSONObject doCat(JSONObject message){
|
||||
try{
|
||||
File directory = new File(Environment.getExternalStorageDirectory().toString() + message.getString("path"));
|
||||
File[] files = directory.listFiles();
|
||||
for (int i = 0; i < files.length; i++)
|
||||
{
|
||||
try{
|
||||
message.accumulate("result",files[i].getName());
|
||||
} catch (Exception e) {}
|
||||
}
|
||||
} catch (Exception e) {}
|
||||
return message;
|
||||
}
|
||||
|
||||
final static int APP_STORAGE_ACCESS_REQUEST_CODE = 501; // Any value
|
||||
private static final String BASE_URI = "https://alexmahr.de";
|
||||
private WebMessagePort port;
|
||||
private void initPort(WebView myWebView) {
|
||||
final WebMessagePort[] channel=myWebView.createWebMessageChannel();
|
||||
port=channel[0];
|
||||
port.setWebMessageCallback(new WebMessagePort.WebMessageCallback() {
|
||||
@Override
|
||||
public void onMessage(WebMessagePort porte, WebMessage message) {
|
||||
try{
|
||||
JSONObject messageJSON = new JSONObject(message.getData());
|
||||
JSONObject reply;
|
||||
if(Objects.equals(messageJSON.getString("function"),"ls"))
|
||||
{
|
||||
reply = doLs(messageJSON);
|
||||
reply.put("super","man");
|
||||
port.postMessage(new WebMessage(reply.toString()));
|
||||
return;
|
||||
}
|
||||
else if(Objects.equals(messageJSON.getString("function"),"cat"))
|
||||
{
|
||||
reply = doCat(messageJSON);
|
||||
reply.put("super","cat");
|
||||
port.postMessage(new WebMessage(reply.toString()));
|
||||
return;
|
||||
}
|
||||
else {
|
||||
reply=messageJSON;
|
||||
reply.put("super","else");
|
||||
reply.accumulate("result",1);
|
||||
reply.accumulate("result","something");
|
||||
port.postMessage(new WebMessage(reply.toString()));
|
||||
}
|
||||
} catch( Exception e) { }
|
||||
}
|
||||
});
|
||||
myWebView.postWebMessage(new WebMessage("init-from-java", new WebMessagePort[]{channel[1]}),Uri.parse(BASE_URI));
|
||||
}
|
||||
|
||||
public String readFileFromAssets(String filename) {
|
||||
String filecontents = "";
|
||||
try {
|
||||
InputStream stream = getAssets().open(filename);
|
||||
int filesize = stream.available();
|
||||
byte[] filebuffer = new byte[filesize];
|
||||
stream.read(filebuffer);
|
||||
stream.close();
|
||||
filecontents = new String(filebuffer);
|
||||
} catch (Exception e) {
|
||||
// I <3 java exceptions
|
||||
}
|
||||
return filecontents;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
// this removes the title bar (a ~1cm big strip at the top of the app showing its name
|
||||
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
|
||||
// we create the webview (at least on the android 14 that is a webview that features avif + websockets etc....)
|
||||
WebView myWebView = new WebView(this);//activityContext);
|
||||
// MyJavascriptInterface myJavaScriptInterface = new MyJavascriptInterface(this,myWebView);
|
||||
// we create a webview (there is also setwebviewclient-vs-setwebchromeclient
|
||||
WebViewClient myWebViewClient= new WebViewClient();
|
||||
myWebView.setWebViewClient(myWebViewClient);
|
||||
// to setup settings
|
||||
WebSettings myWebSettings = myWebView.getSettings();
|
||||
myWebSettings.setBuiltInZoomControls(true);
|
||||
myWebSettings.setDisplayZoomControls(false);
|
||||
myWebSettings.setJavaScriptEnabled(true);
|
||||
myWebView.addJavascriptInterface(this, "myJavaScriptInterface");
|
||||
// load the html from assets file
|
||||
String html = readFileFromAssets("index.html");
|
||||
myWebView.loadDataWithBaseURL(BASE_URI,html, "text/html", "UTF-8",null);
|
||||
//myWebView.loadData(encodedHtml, "text/html", "base64");
|
||||
// alternatively this could be to load a website
|
||||
//myWebView.loadUrl("https://alexmahr.de/ru");
|
||||
setContentView(myWebView);
|
||||
new CountDownTimer(500, 100) {
|
||||
public void onTick(long millisUntilFinished) {
|
||||
try{
|
||||
JSONObject MyJSONObject = new JSONObject("{\"json\":[1,2,3],\"something\":\"test\"}");
|
||||
myWebView.postWebMessage(new WebMessage("this is the message"+millisUntilFinished+ " " + MyJSONObject.get("something")),Uri.parse(BASE_URI));
|
||||
} catch( Exception e) { }
|
||||
// mTextField.setText("seconds remaining: " + millisUntilFinished / 1000);
|
||||
// myWebView.evaluateJavascript("document.body.innerHTML='SUP "+millisUntilFinished+" all is lost';",null);
|
||||
}
|
||||
|
||||
public void onFinish() {
|
||||
initPort(myWebView);//myWebView.evaluateJavascript("document.body.innerHTML='all is lost';",null);
|
||||
}
|
||||
}.start();
|
||||
// Intent intent = new Intent(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION, Uri.parse("package: app.example"));// + BuildConfig.APPLICATION_ID));
|
||||
if(!Environment.isExternalStorageManager()){
|
||||
Intent intent = new Intent();
|
||||
intent.setAction(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION);
|
||||
Uri uri = Uri.fromParts("package", this.getPackageName(), null);
|
||||
intent.setData(uri);
|
||||
startActivity(intent);
|
||||
} else {
|
||||
Toast.makeText(this, "berechtigt", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
//intent.setAction(Settings.ACTION_MANAGE_ALL_FILES_ACCESS_PERMISSION);
|
||||
// startActivityForResult(intent, APP_STORAGE_ACCESS_REQUEST_CODE);
|
||||
}
|
||||
@JavascriptInterface
|
||||
public String toString() {
|
||||
// this.webview.evaluateJavascript("(setTimeout(()=>{document.body.innerHTML='all gone';},2000)()",null);
|
||||
return "this is good";
|
||||
}
|
||||
}
|
||||
|
|
@ -3,7 +3,7 @@ services:
|
|||
build:
|
||||
context: .
|
||||
args:
|
||||
YESACCEPT: ${YESACCEPT:-}
|
||||
YESACCEPT: ${YESACCEPT}
|
||||
stop_grace_period: 1s
|
||||
volumes:
|
||||
- ./apps:/apps
|
||||
- ./apk:/apk
|
||||
|
|
|
@ -1,18 +1,8 @@
|
|||
#!/bin/sh
|
||||
|
||||
set -x
|
||||
|
||||
|
||||
APKDIR="/apps/$1"
|
||||
shift
|
||||
#test -d "$1" ==
|
||||
#APKDIR=
|
||||
#cd /apk/$1;
|
||||
#shift
|
||||
VOLUID="$(stat -c "%u" "$APKDIR")";
|
||||
VOLGID="$(stat -c "%g" "$APKDIR")";
|
||||
#CMD="${*:-"make"}"
|
||||
cd "$APKDIR"
|
||||
test -z "$*" && set -- make
|
||||
setpriv --reuid $VOLUID --regid $VOLGID --clear-groups sh -c "$*"
|
||||
cd /apk;
|
||||
VOLUID="$(stat -c "%u" /apk)";
|
||||
VOLGID="$(stat -c "%g" /apk)";
|
||||
CMD="${*:-"make"}"
|
||||
setpriv --reuid $VOLUID --regid $VOLGID --clear-groups sh -c "$CMD"
|
||||
|
||||
|
|