summaryrefslogtreecommitdiff
path: root/packages/obexpush
diff options
context:
space:
mode:
Diffstat (limited to 'packages/obexpush')
-rw-r--r--packages/obexpush/files/init44
-rw-r--r--packages/obexpush/files/opd_args1
-rw-r--r--packages/obexpush/obexpush-native_1.0.0.bb13
-rw-r--r--packages/obexpush/obexpush/add-obextool.patch461
-rw-r--r--packages/obexpush/obexpush_1.0.0.bb49
5 files changed, 0 insertions, 568 deletions
diff --git a/packages/obexpush/files/init b/packages/obexpush/files/init
deleted file mode 100644
index a9891ef8ad..0000000000
--- a/packages/obexpush/files/init
+++ /dev/null
@@ -1,44 +0,0 @@
-#!/bin/sh
-#
-# Start or stop the OBEX Push daemon.
-#
-# Written by Michael Haynie <mbhaynie@zoominternet.net>
-#
-# It might be better to just edit the bluetooth script,
-# since opd depends heavily on it.
-#
-
-PATH=/bin:/usr/bin:/sbin:/usr/sbin
-
-[ -f /etc/default/rcS ] && . /etc/default/rcS
-[ -f /etc/default/opd_args ] && . /etc/default/opd_args
-
-case "$1" in
- start)
- echo -n "Starting the OBEX Push daemon: "
- start-stop-daemon -S -x /usr/sbin/opd -- --daemonize $OPD_ARGS
- if [ $? = 0 ]; then
- echo "opd."
- else
- echo "(failed.)"
- fi
- ;;
- stop)
- echo -n "Stopping the OBEX Push daemon: "
- start-stop-daemon -K \
- -x /usr/sbin/opd
- echo "opd."
- ;;
- restart|force-reload)
- $0 stop
- $0 start
- exit
- ;;
- *)
- echo "Usage: " $0 " {start|stop|restart|force-reload}"
- exit 1
- ;;
-esac
-
-exit 0
-
diff --git a/packages/obexpush/files/opd_args b/packages/obexpush/files/opd_args
deleted file mode 100644
index 26afc0e249..0000000000
--- a/packages/obexpush/files/opd_args
+++ /dev/null
@@ -1 +0,0 @@
-OPD_ARGS="--mode OBEX --path /var/obexpush --channel 10 --sdp --metadata"
diff --git a/packages/obexpush/obexpush-native_1.0.0.bb b/packages/obexpush/obexpush-native_1.0.0.bb
deleted file mode 100644
index aea07aaa79..0000000000
--- a/packages/obexpush/obexpush-native_1.0.0.bb
+++ /dev/null
@@ -1,13 +0,0 @@
-require obexpush_${PV}.bb
-inherit native
-
-FILESPATH = "${FILE_DIRNAME}/obexpush-${PV}:${FILE_DIRNAME}/obexpush:${FILE_DIRNAME}/files:${FILE_DIRNAME}"
-
-do_stage() {
- :
-}
-
-do_install() {
- :
-}
-
diff --git a/packages/obexpush/obexpush/add-obextool.patch b/packages/obexpush/obexpush/add-obextool.patch
deleted file mode 100644
index 34a7625818..0000000000
--- a/packages/obexpush/obexpush/add-obextool.patch
+++ /dev/null
@@ -1,461 +0,0 @@
-
-#
-# Patch managed by http://www.holgerschurig.de/patcher.html
-#
-
---- obexpush/client/obex_main.c~add-obextool.patch
-+++ obexpush/client/obex_main.c
-@@ -221,12 +221,7 @@
- return NULL;
- }
-
--
-- #ifdef OLDLIBOBEX
-- custfunc.userdata = gt->userdata;
-- #else //OLDLIBOBEX
- custfunc.customdata = gt->userdata;
-- #endif //OLDLIBOBEX
- custfunc.connect = cobex_connect;
- custfunc.disconnect = cobex_disconnect;
- custfunc.write = cobex_write;
---- /dev/null
-+++ obexpush/client/obextool.c
-@@ -0,0 +1,411 @@
-+/*
-+ *
-+ * Bluetooth OBEX tool
-+ *
-+ * Copyright (C) 2002 Marcel Holtmann <marcel@holtmann.org>
-+ *
-+ *
-+ * This program is free software; you can redistribute it and/or modify
-+ * it under the terms of the GNU General Public License as published by
-+ * the Free Software Foundation; either version 2 of the License, or
-+ * (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+ * GNU General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-+ *
-+ */
-+
-+#include <stdio.h>
-+#include <errno.h>
-+#include <fcntl.h>
-+#include <getopt.h>
-+#include <string.h>
-+#include <libgen.h>
-+#include <stdlib.h>
-+#include <unistd.h>
-+#include <sys/stat.h>
-+#include <sys/time.h>
-+#include <sys/param.h>
-+#include <sys/socket.h>
-+
-+#include <bluetooth/bluetooth.h>
-+#include <bluetooth/hci.h>
-+#include <bluetooth/hci_lib.h>
-+#include <bluetooth/rfcomm.h>
-+
-+#include <glib.h>
-+#include <openobex/obex.h>
-+
-+
-+
-+volatile int finished = 0;
-+
-+struct btobex_context_t {
-+ int fd;
-+ bdaddr_t bdaddr;
-+ uint8_t channel;
-+} btobex_context;
-+
-+
-+gint btobex_connect(obex_t *handle, gpointer userdata)
-+{
-+ struct btobex_context_t *context = userdata;
-+ struct sockaddr_rc laddr, raddr;
-+ int s;
-+
-+ if ((s = socket(PF_BLUETOOTH, SOCK_STREAM, BTPROTO_RFCOMM)) < 0) {
-+ printf("Can't create socket. %s (%d)\n", strerror(errno), errno);
-+ return -1;
-+ }
-+
-+ laddr.rc_family = AF_BLUETOOTH;
-+ bacpy(&laddr.rc_bdaddr, BDADDR_ANY);
-+ laddr.rc_channel = 0;
-+ if (bind(s, (struct sockaddr *)&laddr, sizeof(laddr)) < 0) {
-+ printf("Can't bind socket. %s (%d)\n", strerror(errno), errno);
-+ close(s);
-+ return -1;
-+ }
-+
-+ raddr.rc_family = AF_BLUETOOTH;
-+ bacpy(&raddr.rc_bdaddr, &context->bdaddr);
-+ raddr.rc_channel = context->channel;
-+ if (connect(s, (struct sockaddr *)&raddr, sizeof(raddr)) < 0) {
-+ printf("Can't connect. %s (%d)\n", strerror(errno), errno);
-+ close(s);
-+ return -1;
-+ }
-+
-+ context->fd = s;
-+
-+ return 1;
-+}
-+
-+
-+gint btobex_disconnect(obex_t *handle, gpointer userdata)
-+{
-+ struct btobex_context_t *context = userdata;
-+
-+ close(context->fd);
-+
-+ return 1;
-+}
-+
-+
-+gint btobex_listen(obex_t *handle, gpointer userdata)
-+{
-+ printf("The listen command is not implemented\n");
-+
-+ return -1;
-+}
-+
-+
-+gint btobex_write(obex_t *handle, gpointer userdata, guint8 *buffer, gint length)
-+{
-+ struct btobex_context_t *context = userdata;
-+
-+ return (write(context->fd, buffer, length));
-+}
-+
-+
-+gint btobex_handleinput(obex_t *handle, gpointer userdata, gint timeout)
-+{
-+ struct btobex_context_t *context = userdata;
-+ struct timeval to;
-+ fd_set fdset;
-+ unsigned char buf[1024];
-+ int sel, len;
-+
-+ to.tv_sec = timeout;
-+ to.tv_usec = 0;
-+
-+ FD_ZERO(&fdset);
-+ FD_SET(context->fd, &fdset);
-+
-+ len = 0;
-+
-+ if ((sel = select(context->fd + 1, &fdset, NULL, NULL, &to)) > 0) {
-+ if ((len = read(context->fd, buf, sizeof(buf))) > 0)
-+ OBEX_CustomDataFeed(handle, buf, len);
-+ }
-+
-+ return len;
-+}
-+
-+
-+obex_ctrans_t btobex_ctrans = {
-+ customdata: &btobex_context,
-+ connect: btobex_connect,
-+ disconnect: btobex_disconnect,
-+ listen: btobex_listen,
-+ write: btobex_write,
-+ handleinput: btobex_handleinput,
-+};
-+
-+
-+void btobex_event(obex_t *handle, obex_object_t *object, gint mode, gint event, gint obex_cmd, gint obex_rsp)
-+{
-+ switch (event) {
-+ case OBEX_EV_PROGRESS:
-+ break;
-+ case OBEX_EV_ABORT:
-+ printf("Request aborted\n");
-+ finished = 1;
-+ break;
-+ case OBEX_EV_REQDONE:
-+ finished = 1;
-+ break;
-+ case OBEX_EV_REQHINT:
-+ printf("Request hint\n");
-+ break;
-+ case OBEX_EV_REQ:
-+ printf("Server request\n");
-+ break;
-+ case OBEX_EV_LINKERR:
-+ OBEX_TransportDisconnect(handle);
-+ printf("Link broken\n");
-+ break;
-+ case OBEX_EV_PARSEERR:
-+ printf("Parse error\n");
-+ break;
-+ default:
-+ printf("Unknown event 0x%02x\n", event);
-+ break;
-+ }
-+}
-+
-+
-+
-+guint8 *btobex_readfile(const char *filename, int *filesize)
-+{
-+ guint8 *buf;
-+ struct stat stats;
-+ int fd, fs;
-+
-+ stat(filename, &stats);
-+ fs = stats.st_size;
-+
-+ if ((fd = open(filename, O_RDONLY, 0)) < 0)
-+ return NULL;
-+
-+ if (!(buf = g_malloc(fs))) {
-+ close(fd);
-+ return NULL;
-+ }
-+
-+ *filesize = read(fd, buf, fs);
-+
-+ close(fd);
-+
-+ return buf;
-+}
-+
-+
-+int btobex_push(bdaddr_t *bdaddr, uint8_t channel, char *filename, char *alias)
-+{
-+ obex_t *handle;
-+ obex_object_t *object;
-+ obex_headerdata_t hd;
-+
-+ guint8 namebuf[MAXPATHLEN + 1];
-+ int namelen;
-+ guint8 *databuf;
-+ int datalen;
-+
-+ int err;
-+
-+ if (!(handle = OBEX_Init(OBEX_TRANS_CUST, btobex_event, 0))) {
-+ printf("Init of OBEX failed. %s (%d)", strerror(errno), errno);
-+ return -1;
-+ }
-+
-+ bacpy(&btobex_context.bdaddr, bdaddr);
-+ btobex_context.channel = channel;
-+
-+ OBEX_SetUserData(handle, &btobex_context);
-+
-+ if (OBEX_RegisterCTransport(handle, &btobex_ctrans) < 0) {
-+ printf("Custom transport callback registration failed.");
-+ return -1;
-+ }
-+
-+ if (OBEX_TransportConnect(handle, (void *)1, 0) != 1)
-+ return -1;
-+
-+
-+ object = OBEX_ObjectNew(handle, OBEX_CMD_CONNECT);
-+ err = OBEX_Request(handle, object);
-+
-+ finished = 0;
-+ while (!finished) {
-+ if ((err = OBEX_HandleInput(handle, 1)) < 0) {
-+ printf("Error while handling input.\n");
-+ break;
-+ }
-+ }
-+
-+
-+ object = OBEX_ObjectNew(handle, OBEX_CMD_PUT);
-+
-+ namelen = OBEX_CharToUnicode(namebuf, alias, MAXPATHLEN);
-+ hd.bs = namebuf;
-+ OBEX_ObjectAddHeader(handle, object, OBEX_HDR_NAME, hd, namelen, 0);
-+
-+ if (!(databuf = btobex_readfile(filename, &datalen))) {
-+ OBEX_TransportDisconnect(handle);
-+ return -1;
-+ }
-+
-+ hd.bq4 = datalen;
-+ OBEX_ObjectAddHeader(handle, object, OBEX_HDR_LENGTH, hd, sizeof(guint32), 0);
-+
-+ hd.bs = databuf;
-+ OBEX_ObjectAddHeader(handle, object, OBEX_HDR_BODY, hd, datalen, 0);
-+
-+ printf("Sending object ...\n");
-+
-+ err = OBEX_Request(handle, object);
-+
-+ finished = 0;
-+ while (!finished) {
-+ if ((err = OBEX_HandleInput(handle, 1)) < 0) {
-+ printf("Error while handling input.\n");
-+ break;
-+ }
-+ }
-+
-+
-+ object = OBEX_ObjectNew(handle, OBEX_CMD_DISCONNECT);
-+ err = OBEX_Request(handle, object);
-+
-+ finished = 0;
-+ while (!finished) {
-+ if ((err = OBEX_HandleInput(handle, 1)) < 0) {
-+ printf("Error while handling input.\n");
-+ break;
-+ }
-+ }
-+
-+
-+ OBEX_TransportDisconnect(handle);
-+
-+ return 0;
-+}
-+
-+
-+
-+static void usage(void);
-+
-+
-+void cmd_push(bdaddr_t *local, int argc, char **argv)
-+{
-+ char *filename;
-+ char *alias;
-+ bdaddr_t bdaddr;
-+ uint8_t channel;
-+
-+ if (argc < 3) {
-+ usage();
-+ return;
-+ }
-+
-+ filename = argv[1];
-+ alias = basename(filename);
-+ str2ba(argv[2], &bdaddr);
-+ channel = (argc > 3) ? atoi(argv[3]) : 10;
-+
-+ btobex_push(&bdaddr, channel, filename, alias);
-+}
-+
-+
-+struct {
-+ char *cmd;
-+ void (*func)(bdaddr_t *bdaddr, int argc, char **argv);
-+ char *opt;
-+ char *doc;
-+} command[] = {
-+ { "push", cmd_push, "<file> <bdaddr> [channel]", "Push a file" },
-+ { NULL, NULL, 0, 0 }
-+};
-+
-+
-+static void usage(void)
-+{
-+ int i;
-+
-+ printf("Bluetooth OBEX tool\n\n");
-+
-+ printf("Usage:\n"
-+ "\tobextool [options] <command>\n"
-+ "\n");
-+
-+ printf("Options:\n"
-+ "\t-i [hciX|bdaddr] Local HCI device or BD Address\n"
-+ "\t-h, --help Display help\n"
-+ "\n");
-+
-+ printf("Commands:\n");
-+ for (i = 0; command[i].cmd; i++)
-+ printf("\t%-6s %-18s\t%s\n", command[i].cmd,
-+ command[i].opt ? command[i].opt : " ",
-+ command[i].doc);
-+ printf("\n");
-+}
-+
-+
-+static struct option main_options[] = {
-+ { "help", 0, 0, 'h' },
-+ { "device", 1, 0, 'i' },
-+ { 0, 0, 0, 0 }
-+};
-+
-+
-+int main(int argc, char *argv[])
-+{
-+ bdaddr_t bdaddr;
-+ int i, opt;
-+
-+ bacpy(&bdaddr, BDADDR_ANY);
-+
-+ while ((opt = getopt_long(argc, argv, "+i:h", main_options, NULL)) != -1) {
-+ switch(opt) {
-+ case 'i':
-+ if (strncmp(optarg, "hci", 3) == 0)
-+ hci_devba(atoi(optarg + 3), &bdaddr);
-+ else
-+ str2ba(optarg, &bdaddr);
-+ break;
-+ case 'h':
-+ usage();
-+ exit(0);
-+ default:
-+ exit(0);
-+ }
-+ }
-+
-+ argc -= optind;
-+ argv += optind;
-+ optind = 0;
-+
-+ if (argc < 1) {
-+ usage();
-+ exit(0);
-+ }
-+
-+ for (i = 0; command[i].cmd; i++) {
-+ if (strncmp(command[i].cmd, argv[0], 3))
-+ continue;
-+ command[i].func(&bdaddr, argc, argv);
-+ exit(0);
-+ }
-+
-+ usage();
-+
-+ return 0;
-+}
---- obexpush/client/Makefile~add-obextool.patch
-+++ obexpush/client/Makefile
-@@ -35,11 +35,21 @@
- #
-
- ussp-push: obex_main.o obex_socket.o
-- gcc obex_main.o obex_socket.o ${GLIBLIB} ${OBEXLIB} -o ussp-push
-+ $(CC) obex_main.o obex_socket.o ${GLIBLIB} ${OBEXLIB} -o ussp-push
-
- obex_main.o: obex_main.c obex_socket.h
-- gcc ${OBEXINC} ${GLIBINC} -c obex_main.c -o obex_main.o
-+ $(CC) ${OBEXINC} ${GLIBINC} -c obex_main.c -o obex_main.o
-
- obex_socket.o: obex_socket.c obex_socket.h
-- gcc ${OBEXINC} ${GLIBINC} -c obex_socket.c -o obex_socket.o
-+ $(CC) ${OBEXINC} ${GLIBINC} -c obex_socket.c -o obex_socket.o
-+
-+
-+
-+obextool: obextool.o
-+ $(CC) obextool.o ${GLIBLIB} ${OBEXLIB} -lbluetooth -o obextool
-+
-+obextool.o: obextool.c
-+ $(CC) ${OBEXINC} ${GLIBINC} -c obextool.c -o obextool.o
-+
-+all: ussp-push obextool
-
diff --git a/packages/obexpush/obexpush_1.0.0.bb b/packages/obexpush/obexpush_1.0.0.bb
deleted file mode 100644
index cfc09df2b6..0000000000
--- a/packages/obexpush/obexpush_1.0.0.bb
+++ /dev/null
@@ -1,49 +0,0 @@
-DESCRIPTION = "Obex Push Utilities"
-HOMEPAGE = "http://www.caside.lancs.ac.uk/java_bt.php"
-SECTION = "console/network"
-LICENSE = "GPL"
-DEPENDS = "glib-2.0 openobex bluez-libs"
-PR = "r4"
-
-SRC_URI = "http://www.caside.lancs.ac.uk/bt/obexpush.tar.gz \
- file://add-obextool.patch;patch=1 \
- file://init \
- file://opd_args"
-S = "${WORKDIR}/obexpush"
-
-inherit update-rc.d
-
-INITSCRIPT_NAME = "opd"
-INITSCRIPT_PARAMS = "defaults 33 09"
-
-export GLIBINC = "-I${STAGING_INCDIR}/glib-2.0"
-export GLIBLIB = "-I${STAGING_LIBDIR} -lglib-2.0"
-export OBEXINC = "-I${STAGING_INCDIR}"
-export OBEXLIB = "-L${STAGING_LIBDIR} -Wl,-rpath,${STAGING_LIBDIR} -lopenobex"
-
-do_configure() {
- rm -f client/*.o client/ussp-push
- rm -f opd/*.o opd/opd
- sed -i 's:gcc:${CC}:' */Makefile
- sed -i 's:__FUNCTION__::' opd/*.c
-}
-
-do_compile() {
- oe_runmake -C client ussp-push
- oe_runmake -C client obextool
- oe_runmake -C opd
-}
-
-do_install() {
- install -d ${D}${bindir}
- install -d ${D}${sbindir}
- install -m 0755 client/ussp-push ${D}${bindir}
- install -m 0755 client/obextool ${D}${bindir}
- install -m 0755 opd/opd ${D}${sbindir}
-
- install -d ${D}${sysconfdir}/init.d
- install -d ${D}${sysconfdir}/default
- install -m 0755 ${WORKDIR}/init ${D}${sysconfdir}/init.d/opd
- install -m 0755 ${WORKDIR}/opd_args ${D}${sysconfdir}/default/opd_args
-}
-