aboutsummaryrefslogtreecommitdiffstats
path: root/src/frontends/android/jni/libandroidbridge/backend/android_service.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2012-08-08 14:51:59 +0200
committerTobias Brunner <tobias@strongswan.org>2012-08-13 11:09:34 +0200
commitd9531100fac082a803b2d2d4a7505a638ab1d3dd (patch)
tree4508d8ee0ca44288edfdcd9191e558e7f4851839 /src/frontends/android/jni/libandroidbridge/backend/android_service.c
parent3b3cf0c87ae5a73fad48933ff070f4b8ec919d98 (diff)
downloadstrongswan-d9531100fac082a803b2d2d4a7505a638ab1d3dd.tar.bz2
strongswan-d9531100fac082a803b2d2d4a7505a638ab1d3dd.tar.xz
Added a handler that writes inbound plain text packets to the TUN device
Diffstat (limited to 'src/frontends/android/jni/libandroidbridge/backend/android_service.c')
-rw-r--r--src/frontends/android/jni/libandroidbridge/backend/android_service.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/frontends/android/jni/libandroidbridge/backend/android_service.c b/src/frontends/android/jni/libandroidbridge/backend/android_service.c
index bd28e7de9..417a8aa70 100644
--- a/src/frontends/android/jni/libandroidbridge/backend/android_service.c
+++ b/src/frontends/android/jni/libandroidbridge/backend/android_service.c
@@ -15,6 +15,8 @@
* for more details.
*/
+#include <unistd.h>
+
#include "android_service.h"
#include "../charonservice.h"
#include "../vpnservice_builder.h"
@@ -80,6 +82,35 @@ static void send_esp(void *data, esp_packet_t *packet)
}
/**
+ * Inbound callback
+ */
+static void deliver_plain(private_android_service_t *this,
+ ip_packet_t *packet)
+{
+ chunk_t encoding;
+ ssize_t len;
+
+ encoding = packet->get_encoding(packet);
+
+ this->lock->read_lock(this->lock);
+ if (this->tunfd < 0)
+ { /* the TUN device is already closed */
+ this->lock->unlock(this->lock);
+ packet->destroy(packet);
+ return;
+ }
+ len = write(this->tunfd, encoding.ptr, encoding.len);
+ this->lock->unlock(this->lock);
+
+ if (len < 0 || len != encoding.len)
+ {
+ DBG1(DBG_DMN, "failed to write packet to TUN device: %s",
+ strerror(errno));
+ }
+ packet->destroy(packet);
+}
+
+/**
* Receiver callback
*/
static void receiver_esp_cb(void *data, packet_t *packet)
@@ -179,6 +210,8 @@ static bool setup_tun_device(private_android_service_t *this,
charon->receiver->add_esp_cb(charon->receiver,
(receiver_esp_cb_t)receiver_esp_cb, NULL);
+ ipsec->processor->register_inbound(ipsec->processor,
+ (ipsec_inbound_cb_t)deliver_plain, this);
ipsec->processor->register_outbound(ipsec->processor,
(ipsec_outbound_cb_t)send_esp, NULL);
@@ -204,6 +237,8 @@ static void close_tun_device(private_android_service_t *this)
ipsec->processor->unregister_outbound(ipsec->processor,
(ipsec_outbound_cb_t)send_esp);
+ ipsec->processor->unregister_inbound(ipsec->processor,
+ (ipsec_inbound_cb_t)deliver_plain);
charon->receiver->del_esp_cb(charon->receiver,
(receiver_esp_cb_t)receiver_esp_cb);
close(tunfd);