summaryrefslogtreecommitdiff
path: root/app/jni
diff options
context:
space:
mode:
authorParménides GV <parmegv@sdf.org>2014-04-09 16:03:55 +0200
committerParménides GV <parmegv@sdf.org>2014-04-09 16:07:34 +0200
commit1684c8f398922065a97e7da4dac4ac6a33cc5218 (patch)
tree76a4b11ae0d7b217c088f3c2b8fc7e69a7b8ae0d /app/jni
parentb9a2b085a8f508cd09e2639c70be845c992c4a3e (diff)
Back to the standard "app" module.
This return to "app" instead of "bitmask_android" is due to this reading: https://developer.android.com/sdk/installing/studio-build.html#projectStructure I'll have to tweak the final apk name in build.gradle.
Diffstat (limited to 'app/jni')
-rw-r--r--app/jni/Android.mk29
-rw-r--r--app/jni/Application.mk8
-rw-r--r--app/jni/buildall.mk69
-rw-r--r--app/jni/jbcrypto.cpp90
-rw-r--r--app/jni/jniglue.c22
-rw-r--r--app/jni/jniglue.h12
-rw-r--r--app/jni/minivpn.c0
-rw-r--r--app/jni/prebuilt.mk27
8 files changed, 257 insertions, 0 deletions
diff --git a/app/jni/Android.mk b/app/jni/Android.mk
new file mode 100644
index 00000000..3514b920
--- /dev/null
+++ b/app/jni/Android.mk
@@ -0,0 +1,29 @@
+# Path of the sources
+JNI_DIR := $(call my-dir)
+
+include lzo/Android.mk
+
+include openssl/Android.mk
+
+include openvpn/Android.mk
+
+
+LOCAL_PATH := $(JNI_DIR)
+
+# The only real JNI library
+include $(CLEAR_VARS)
+LOCAL_LDLIBS := -llog -lz
+LOCAL_C_INCLUDES := openssl/include openssl/crypto openssl
+LOCAL_SRC_FILES:= jniglue.c jbcrypto.cpp
+LOCAL_MODULE = opvpnutil
+LOCAL_SHARED_LIBRARIES := libcrypto
+include $(BUILD_SHARED_LIBRARY)
+
+
+include $(CLEAR_VARS)
+LOCAL_LDLIBS := -lz -lc
+LOCAL_SHARED_LIBRARIES := libssl libcrypto openvpn
+LOCAL_SRC_FILES:= minivpn.c
+LOCAL_MODULE = minivpn
+include $(BUILD_EXECUTABLE)
+
diff --git a/app/jni/Application.mk b/app/jni/Application.mk
new file mode 100644
index 00000000..0795b5b8
--- /dev/null
+++ b/app/jni/Application.mk
@@ -0,0 +1,8 @@
+APP_ABI := all
+NDK_TOOLCHAIN_VERSION=4.8
+APP_PLATFORM := android-14
+APP_STL:=stlport_static
+
+#APP_OPTIM := release
+
+#LOCAL_ARM_MODE := arm
diff --git a/app/jni/buildall.mk b/app/jni/buildall.mk
new file mode 100644
index 00000000..e1d6fdbc
--- /dev/null
+++ b/app/jni/buildall.mk
@@ -0,0 +1,69 @@
+# Build curl
+include $(CURRENT_DIR)/curl/Android.mk
+
+
+include $(CLEAR_VARS)
+
+
+# SIGC++ Library built as static library
+LOCAL_MODULE := sigc
+LOCAL_PATH = $(CURRENT_DIR)
+LOCAL_CPP_EXTENSION := .cc
+
+
+
+LOCAL_SRC_FILES := sigc++/signal.cc sigc++/signal_base.cc sigc++/trackable.cc
+LOCAL_SRC_FILES += sigc++/functors/slot_base.cc sigc++/adaptors/lambda/lambda.cc
+LOCAL_SRC_FILES += sigc++/connection.cc sigc++/functors/slot.cc
+
+
+LOCAL_C_INCLUDES := sigc++
+
+include $(BUILD_STATIC_LIBRARY)
+
+# Torrent library
+
+include $(CLEAR_VARS)
+
+
+LOCAL_PATH := $(CURRENT_DIR)/libtorrent/src
+LOCAL_C_INCLUDES := $(CURRENT_DIR)/libtorrent $(CURRENT_DIR) $(CURRENT_DIR)/libtorrent/src $(CURRENT_DIR)/libtorrent/src/torrent
+LOCAL_CPP_EXTENSION := .cc
+LOCAL_MODULE = rtorrent
+
+LOCAL_SRC_FILES = globals.cc resource_manager.cc manager.cc
+
+#torrent subdirs
+LOCAL_SRC_FILES+= torrent/data/block.cc torrent/data/block_list.cc torrent/data/chunk_utils.cc torrent/data/file.cc torrent/data/file_list.cc torrent/data/file_list_iterator.cc torrent/data/file_manager.cc torrent/data/file_utils.cc torrent/data/transfer_list.cc torrent/peer/client_info.cc torrent/peer/client_list.cc torrent/peer/connection_list.cc torrent/peer/peer.cc torrent/peer/peer_info.cc torrent/peer/peer_list.cc
+
+
+
+#data
+LOCAL_SRC_FILES+= data/chunk.cc data/chunk_list.cc data/chunk_part.cc data/hash_chunk.cc data/hash_queue.cc data/hash_queue_node.cc data/hash_torrent.cc data/memory_chunk.cc data/socket_file.cc
+
+# dht
+LOCAL_SRC_FILES+= dht/dht_bucket.cc dht/dht_node.cc dht/dht_router.cc dht/dht_server.cc dht/dht_tracker.cc dht/dht_transaction.cc
+
+#download
+LOCAL_SRC_FILES+= download/available_list.cc download/choke_manager.cc download/chunk_selector.cc download/chunk_statistics.cc download/delegator.cc download/download_constructor.cc download/download_main.cc download/download_manager.cc download/download_wrapper.cc
+
+# net
+LOCAL_SRC_FILES+=net/address_list.cc net/listen.cc net/socket_base.cc net/socket_datagram.cc net/socket_fd.cc net/socket_set.cc net/socket_stream.cc net/throttle_internal.cc net/throttle_list.cc
+
+#protocol
+LOCAL_SRC_FILES+=protocol/extensions.cc protocol/handshake.cc protocol/handshake_encryption.cc protocol/handshake_manager.cc protocol/initial_seed.cc protocol/peer_connection_base.cc protocol/peer_connection_leech.cc protocol/peer_connection_metadata.cc protocol/peer_factory.cc protocol/request_list.cc
+
+# torrent
+LOCAL_SRC_FILES+= torrent/bitfield.cc torrent/chunk_manager.cc torrent/connection_manager.cc torrent/dht_manager.cc torrent/download.cc torrent/error.cc torrent/exceptions.cc torrent/hash_string.cc torrent/http.cc torrent/object.cc torrent/object_static_map.cc torrent/object_stream.cc torrent/path.cc torrent/poll_epoll.cc torrent/poll_kqueue.cc torrent/poll_select.cc torrent/rate.cc torrent/resume.cc torrent/thread_base.cc torrent/throttle.cc torrent/torrent.cc torrent/tracker.cc torrent/tracker_list.cc
+
+
+#tracker
+LOCAL_SRC_FILES+= tracker/tracker_dht.cc tracker/tracker_http.cc tracker/tracker_manager.cc tracker/tracker_udp.cc
+
+#utils
+LOCAL_SRC_FILES+= utils/diffie_hellman.cc utils/sha_fast.cc
+
+
+LOCAL_STATIC_LIBRARIES := sigc
+
+include $(BUILD_STATIC_LIBRARY)
diff --git a/app/jni/jbcrypto.cpp b/app/jni/jbcrypto.cpp
new file mode 100644
index 00000000..1c3e3ca9
--- /dev/null
+++ b/app/jni/jbcrypto.cpp
@@ -0,0 +1,90 @@
+//
+// JBCyrpto.cpp
+// xcopenvpn
+//
+// Created by Arne Schwabe on 12.07.12.
+// Copyright (c) 2012 Universität Paderborn. All rights reserved.
+//
+
+#include <jni.h>
+
+#include <openssl/ssl.h>
+#include <openssl/rsa.h>
+#include <openssl/objects.h>
+#include <openssl/md5.h>
+#include <android/log.h>
+#include <openssl/err.h>
+
+
+extern "C" {
+jbyteArray Java_se_leap_openvpn_OpenVpnManagementThread_rsasign(JNIEnv* env, jclass, jbyteArray from, jint pkeyRef);
+}
+
+int jniThrowException(JNIEnv* env, const char* className, const char* msg) {
+
+ jclass exceptionClass = env->FindClass(className);
+
+ if (exceptionClass == NULL) {
+ __android_log_print(ANDROID_LOG_DEBUG,"openvpn","Unable to find exception class %s", className);
+ /* ClassNotFoundException now pending */
+ return -1;
+ }
+
+ if (env->ThrowNew( exceptionClass, msg) != JNI_OK) {
+ __android_log_print(ANDROID_LOG_DEBUG,"openvpn","Failed throwing '%s' '%s'", className, msg);
+ /* an exception, most likely OOM, will now be pending */
+ return -1;
+ }
+
+ env->DeleteLocalRef(exceptionClass);
+ return 0;
+}
+
+
+jbyteArray Java_se_leap_openvpn_OpenVpnManagementThread_rsasign(JNIEnv* env, jclass, jbyteArray from, jint pkeyRef) {
+
+ // EVP_MD_CTX* ctx = reinterpret_cast<EVP_MD_CTX*>(ctxRef);
+ EVP_PKEY* pkey = reinterpret_cast<EVP_PKEY*>(pkeyRef);
+
+
+ if (pkey == NULL || from == NULL) {
+ jniThrowException(env, "java/lang/NullPointerException", "EVP_KEY is null");
+ return NULL;
+ }
+
+ jbyte* data = env-> GetByteArrayElements (from, NULL);
+ int datalen = env-> GetArrayLength(from);
+
+ if(data==NULL )
+ jniThrowException(env, "java/lang/NullPointerException", "data is null");
+
+ unsigned int siglen;
+ unsigned char* sigret = (unsigned char*)malloc(RSA_size(pkey->pkey.rsa));
+
+
+ //int RSA_sign(int type, const unsigned char *m, unsigned int m_len,
+ // unsigned char *sigret, unsigned int *siglen, RSA *rsa);
+
+ // adapted from s3_clnt.c
+ if (RSA_sign(NID_md5_sha1, (unsigned char*) data, datalen,
+ sigret, &siglen, pkey->pkey.rsa) <= 0 )
+ {
+
+ jniThrowException(env, "java/security/InvalidKeyException", "rsa_sign went wrong, see logcat");
+
+ ERR_print_errors_fp(stderr);
+ return NULL;
+
+
+ }
+
+
+ jbyteArray jb;
+
+ jb =env->NewByteArray(siglen);
+
+ env->SetByteArrayRegion(jb, 0, siglen, (jbyte *) sigret);
+ free(sigret);
+ return jb;
+
+}
diff --git a/app/jni/jniglue.c b/app/jni/jniglue.c
new file mode 100644
index 00000000..143cd10b
--- /dev/null
+++ b/app/jni/jniglue.c
@@ -0,0 +1,22 @@
+#include <jni.h>
+#include <android/log.h>
+#include <stdlib.h>
+#include <setjmp.h>
+
+#include "jniglue.h"
+
+jint JNI_OnLoad(JavaVM *vm, void *reserved) {
+ __android_log_write(ANDROID_LOG_DEBUG,"openvpn", "Loading openvpn native library $id$ compiled on " __DATE__ " " __TIME__ );
+ return JNI_VERSION_1_2;
+}
+
+
+void android_openvpn_log(int level,const char* prefix,const char* prefix_sep,const char* m1)
+{
+ __android_log_print(ANDROID_LOG_DEBUG,"openvpn","%s%s%s",prefix,prefix_sep,m1);
+}
+
+void Java_se_leap_openvpn_OpenVpnManagementThread_jniclose(JNIEnv *env,jclass jo, jint fd) {
+ int ret = close(fd);
+}
+
diff --git a/app/jni/jniglue.h b/app/jni/jniglue.h
new file mode 100644
index 00000000..a86d52da
--- /dev/null
+++ b/app/jni/jniglue.h
@@ -0,0 +1,12 @@
+//
+// jniglue.h
+// xcopenvpn
+//
+// Created by Arne Schwabe on 29.03.12.
+// Copyright (c) 2012 Universität Paderborn. All rights reserved.
+//
+
+#ifndef xcopenvpn_jniglue_h
+#define xcopenvpn_jniglue_h
+void android_openvpn_log(int level,const char* prefix,const char* prefix_sep,const char* m1);
+#endif
diff --git a/app/jni/minivpn.c b/app/jni/minivpn.c
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/app/jni/minivpn.c
diff --git a/app/jni/prebuilt.mk b/app/jni/prebuilt.mk
new file mode 100644
index 00000000..51bf1003
--- /dev/null
+++ b/app/jni/prebuilt.mk
@@ -0,0 +1,27 @@
+# Build curl
+
+include $(CLEAR_VARS)
+LOCAL_MODULE := curl
+LOCAL_SRC_FILES := prebuilt/libcurl.a
+LOCAL_PATH = $(CURRENT_DIR)
+
+include $(PREBUILT_STATIC_LIBRARY)
+
+# SIGC
+
+include $(CLEAR_VARS)
+LOCAL_MODULE := sigc
+LOCAL_SRC_FILES := prebuilt/libsigc.a
+LOCAL_PATH = $(CURRENT_DIR)
+
+include $(PREBUILT_STATIC_LIBRARY)
+
+include $(CLEAR_VARS)
+# Torrent library
+LOCAL_MODULE := rtorrent
+LOCAL_SRC_FILES := prebuilt/librtorrent.a
+LOCAL_PATH = $(CURRENT_DIR)
+
+LOCAL_STATIC_LIBRARIES := sigc
+
+include $(PREBUILT_STATIC_LIBRARY)