mirror of
http://galexander.org/git/simplesshd.git
synced 2025-01-01 02:40:52 +00:00
Find native lib directory the correct way, using
Context.getApplicationInfo().nativeLibraryDir.
This commit is contained in:
parent
7db95c7815
commit
22d7993e23
3
NOTES
3
NOTES
@ -698,15 +698,12 @@ Anyways, there's a bunch of stuff remaining to do, and then I will
|
|||||||
release it.
|
release it.
|
||||||
|
|
||||||
|
|
||||||
XXX - find location of native libs (it no longer updates the lib-> symlink!)
|
|
||||||
|
|
||||||
XXX - call checkSelfPermission/requestPermission to get WRITE_EXTERNAL_STORAGE (it only works now because it's grandfathered in)
|
XXX - call checkSelfPermission/requestPermission to get WRITE_EXTERNAL_STORAGE (it only works now because it's grandfathered in)
|
||||||
|
|
||||||
XXX - fix color problem with newest API (override all colors, i think only the STOP/START button remains?)
|
XXX - fix color problem with newest API (override all colors, i think only the STOP/START button remains?)
|
||||||
|
|
||||||
XXX - upgrade to newest dropbear
|
XXX - upgrade to newest dropbear
|
||||||
|
|
||||||
XXX - reference lib dir by files dir /../lib, test it by logging in as "Guest"
|
|
||||||
XXX - figure out what pie does to the boot event receiver
|
XXX - figure out what pie does to the boot event receiver
|
||||||
|
|
||||||
XXX - see if settings looks better with SDK26, if not, hack it so that the ones with strings have their states shown
|
XXX - see if settings looks better with SDK26, if not, hack it so that the ones with strings have their states shown
|
||||||
|
@ -20,6 +20,7 @@ public class SimpleSSHDService extends Service {
|
|||||||
private static long sshd_when = 0;
|
private static long sshd_when = 0;
|
||||||
private static long sshd_duration = 0;
|
private static long sshd_duration = 0;
|
||||||
private static boolean foregrounded = false;
|
private static boolean foregrounded = false;
|
||||||
|
private static String libdir = null;
|
||||||
|
|
||||||
public void onCreate() {
|
public void onCreate() {
|
||||||
super.onCreate();
|
super.onCreate();
|
||||||
@ -32,6 +33,7 @@ public class SimpleSSHDService extends Service {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public int onStartCommand(Intent intent, int flags, int startId) {
|
public int onStartCommand(Intent intent, int flags, int startId) {
|
||||||
|
libdir = getApplicationInfo().nativeLibraryDir;
|
||||||
if ((intent == null) ||
|
if ((intent == null) ||
|
||||||
(!intent.getBooleanExtra("stop", false))) {
|
(!intent.getBooleanExtra("stop", false))) {
|
||||||
do_start();
|
do_start();
|
||||||
@ -130,7 +132,7 @@ public class SimpleSSHDService extends Service {
|
|||||||
Prefs.get_path(), Prefs.get_shell(),
|
Prefs.get_path(), Prefs.get_shell(),
|
||||||
Prefs.get_home(), Prefs.get_extra(),
|
Prefs.get_home(), Prefs.get_extra(),
|
||||||
(Prefs.get_rsyncbuffer() ? 1 : 0),
|
(Prefs.get_rsyncbuffer() ? 1 : 0),
|
||||||
Prefs.get_env());
|
Prefs.get_env(), libdir);
|
||||||
|
|
||||||
long now = System.currentTimeMillis();
|
long now = System.currentTimeMillis();
|
||||||
if (pid != 0) {
|
if (pid != 0) {
|
||||||
@ -179,7 +181,7 @@ public class SimpleSSHDService extends Service {
|
|||||||
|
|
||||||
private static native int start_sshd(int port, String path,
|
private static native int start_sshd(int port, String path,
|
||||||
String shell, String home, String extra,
|
String shell, String home, String extra,
|
||||||
int rsyncbuffer, String env);
|
int rsyncbuffer, String env, String lib);
|
||||||
private static native void kill(int pid);
|
private static native void kill(int pid);
|
||||||
private static native int waitpid(int pid);
|
private static native int waitpid(int pid);
|
||||||
static {
|
static {
|
||||||
|
@ -613,6 +613,8 @@ install_environment(void)
|
|||||||
m_free(v);
|
m_free(v);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setenv("SSHD_LIBDIR", conf_lib, /*overwrite=*/1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -627,18 +629,16 @@ void run_shell_command(const char* cmd, unsigned int maxfd, char* usershell) {
|
|||||||
baseshell = basename(usershell);
|
baseshell = basename(usershell);
|
||||||
|
|
||||||
if (cmd && !strncmp(cmd, "scp ", 4)) {
|
if (cmd && !strncmp(cmd, "scp ", 4)) {
|
||||||
char *t = m_malloc(strlen(cmd)+strlen(NDK_EXECUTABLES_PATH)+80);
|
char *t = m_malloc(strlen(cmd)+strlen(conf_lib)+80);
|
||||||
sprintf(t, "%s/lib%s.so %s", NDK_EXECUTABLES_PATH, "scp",
|
sprintf(t, "%s/lib%s.so %s", conf_lib, "scp", cmd+4);
|
||||||
cmd+4);
|
|
||||||
cmd = t;
|
cmd = t;
|
||||||
} else if (cmd && !strncmp(cmd, "rsync ", 6)) {
|
} else if (cmd && !strncmp(cmd, "rsync ", 6)) {
|
||||||
char *t = m_malloc(strlen(cmd)+strlen(NDK_EXECUTABLES_PATH)+80);
|
char *t = m_malloc(strlen(cmd)+strlen(conf_lib)+80);
|
||||||
char *x = "rsync";
|
char *x = "rsync";
|
||||||
if (conf_rsyncbuffer) {
|
if (conf_rsyncbuffer) {
|
||||||
x = "buffersu";
|
x = "buffersu";
|
||||||
}
|
}
|
||||||
sprintf(t, "%s/lib%s.so %s", NDK_EXECUTABLES_PATH, x,
|
sprintf(t, "%s/lib%s.so %s", conf_lib, x, cmd+6);
|
||||||
cmd+6);
|
|
||||||
cmd = t;
|
cmd = t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -263,7 +263,7 @@ much traffic. */
|
|||||||
* "-q" for quiet */
|
* "-q" for quiet */
|
||||||
#undef XAUTH_COMMAND
|
#undef XAUTH_COMMAND
|
||||||
|
|
||||||
#define SFTPSERVER_PATH NDK_EXECUTABLES_PATH "/libsftp-server.so"
|
#define SFTPSERVER_PATH "%s/libsftp-server.so" /*, conf_lib */
|
||||||
|
|
||||||
/* This is used by the scp binary when used as a client binary. If you're
|
/* This is used by the scp binary when used as a client binary. If you're
|
||||||
* not using the Dropbear client, you'll need to change it */
|
* not using the Dropbear client, you'll need to change it */
|
||||||
|
@ -663,7 +663,8 @@ static int sessioncommand(struct Channel *channel, struct ChanSess *chansess,
|
|||||||
#ifdef SFTPSERVER_PATH
|
#ifdef SFTPSERVER_PATH
|
||||||
if ((cmdlen == 4) && strncmp(chansess->cmd, "sftp", 4) == 0) {
|
if ((cmdlen == 4) && strncmp(chansess->cmd, "sftp", 4) == 0) {
|
||||||
m_free(chansess->cmd);
|
m_free(chansess->cmd);
|
||||||
chansess->cmd = m_strdup(SFTPSERVER_PATH);
|
chansess->cmd = m_malloc(strlen(SFTPSERVER_PATH) + strlen(conf_lib) + 2);
|
||||||
|
sprintf(chansess->cmd, SFTPSERVER_PATH, conf_lib);
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
|
||||||
#define WRAPPED_CMD "/data/data/org.galexander.sshd/lib/librsync.so"
|
#define WRAPPED_CMD "%s/librsync.so"
|
||||||
#define WRAPPED_ARG0 "rsync"
|
#define WRAPPED_ARG0 "rsync"
|
||||||
#define MAX_BUFSZ (1024*1024)
|
#define MAX_BUFSZ (1024*1024)
|
||||||
|
|
||||||
@ -133,10 +133,18 @@ buf_write(struct buf *b, int fd)
|
|||||||
int
|
int
|
||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
char *libdir;
|
||||||
|
char *wrapped_cmd;
|
||||||
int p0[2], p1[2];
|
int p0[2], p1[2];
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
pipe(p0);
|
pipe(p0);
|
||||||
pipe(p1);
|
pipe(p1);
|
||||||
|
|
||||||
|
libdir = getenv("SSHD_LIBDIR");
|
||||||
|
if (!libdir) { libdir = "SSHD_LIBDIR_not_set"; }
|
||||||
|
wrapped_cmd = malloc(strlen(libdir) + strlen(WRAPPED_CMD) + 2);
|
||||||
|
sprintf(wrapped_cmd, WRAPPED_CMD, libdir);
|
||||||
|
|
||||||
if ((pid=fork())) {
|
if ((pid=fork())) {
|
||||||
/* parent */
|
/* parent */
|
||||||
fd_set ifds, ofds;
|
fd_set ifds, ofds;
|
||||||
@ -225,7 +233,7 @@ T(ofd)
|
|||||||
memcpy(child_argv, argv, argc*sizeof *child_argv);
|
memcpy(child_argv, argv, argc*sizeof *child_argv);
|
||||||
child_argv[0] = WRAPPED_ARG0;
|
child_argv[0] = WRAPPED_ARG0;
|
||||||
child_argv[argc] = NULL;
|
child_argv[argc] = NULL;
|
||||||
execv(WRAPPED_CMD, child_argv);
|
execv(wrapped_cmd, child_argv);
|
||||||
perror("execv");
|
perror("execv");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -32,8 +32,6 @@
|
|||||||
#define DBMULTI_dropbear 1
|
#define DBMULTI_dropbear 1
|
||||||
#define DROPBEAR_MULTI 1
|
#define DROPBEAR_MULTI 1
|
||||||
|
|
||||||
#define NDK_EXECUTABLES_PATH "/data/data/org.galexander.sshd/lib"
|
|
||||||
|
|
||||||
|
|
||||||
/* in jni/interface.c: */
|
/* in jni/interface.c: */
|
||||||
extern const char *conf_path;
|
extern const char *conf_path;
|
||||||
@ -42,6 +40,7 @@ extern const char *conf_home;
|
|||||||
const char *conf_path_file(const char *fn);
|
const char *conf_path_file(const char *fn);
|
||||||
extern int conf_rsyncbuffer;
|
extern int conf_rsyncbuffer;
|
||||||
extern const char *conf_env;
|
extern const char *conf_env;
|
||||||
|
extern const char *conf_lib;
|
||||||
|
|
||||||
|
|
||||||
#endif /* __CONFIG_H__ */
|
#endif /* __CONFIG_H__ */
|
||||||
|
@ -9,7 +9,8 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
const char *conf_path = "", *conf_shell = "", *conf_home = "", *conf_env = "";
|
const char *conf_path = "", *conf_shell = "", *conf_home = "", *conf_env = "",
|
||||||
|
*conf_lib = "";
|
||||||
int conf_rsyncbuffer = 0;
|
int conf_rsyncbuffer = 0;
|
||||||
|
|
||||||
/* NB - this will leak memory like crazy if called often.... */
|
/* NB - this will leak memory like crazy if called often.... */
|
||||||
@ -103,6 +104,9 @@ static const char *
|
|||||||
from_java_string(jobject s)
|
from_java_string(jobject s)
|
||||||
{
|
{
|
||||||
const char *ret, *t;
|
const char *ret, *t;
|
||||||
|
if (!s) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
t = (*env)->GetStringUTFChars(env, s, NULL);
|
t = (*env)->GetStringUTFChars(env, s, NULL);
|
||||||
if (!t) {
|
if (!t) {
|
||||||
return "";
|
return "";
|
||||||
@ -116,7 +120,7 @@ JNIEXPORT jint JNICALL
|
|||||||
Java_org_galexander_sshd_SimpleSSHDService_start_1sshd(JNIEnv *env_,
|
Java_org_galexander_sshd_SimpleSSHDService_start_1sshd(JNIEnv *env_,
|
||||||
jclass cl,
|
jclass cl,
|
||||||
jint port, jobject jpath, jobject jshell, jobject jhome, jobject jextra,
|
jint port, jobject jpath, jobject jshell, jobject jhome, jobject jextra,
|
||||||
jint rsyncbuffer, jobject jenv)
|
jint rsyncbuffer, jobject jenv, jobject jlib)
|
||||||
{
|
{
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
const char *extra;
|
const char *extra;
|
||||||
@ -130,6 +134,7 @@ Java_org_galexander_sshd_SimpleSSHDService_start_1sshd(JNIEnv *env_,
|
|||||||
extra = from_java_string(jextra);
|
extra = from_java_string(jextra);
|
||||||
conf_rsyncbuffer = rsyncbuffer;
|
conf_rsyncbuffer = rsyncbuffer;
|
||||||
conf_env = from_java_string(jenv);
|
conf_env = from_java_string(jenv);
|
||||||
|
conf_lib = from_java_string(jlib);
|
||||||
|
|
||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid == 0) {
|
if (pid == 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user