public inbox for linux-bluetooth@vger.kernel.org
 help / color / mirror / Atom feed
From: Frederic Danis <frederic.danis@palmsource.com>
To: BlueZ development <bluez-devel@lists.sourceforge.net>
Subject: Re: [Bluez-devel] DBus	interface	-	determining	whether	a	device	exists
Date: Tue, 07 Nov 2006 18:28:43 +0100	[thread overview]
Message-ID: <4550C24B.9080703@palmsource.com> (raw)
In-Reply-To: <45390275.1010607@palmsource.com>

Hello,

Are you OK with this patch ?

Regards

Fred

-----------------------------------------------
It is not by improving the oil lamp that one invents the electric bulb!
-----------------------------------------------
Danis Frederic            PalmSource Europe
Software engineer
Mail : mailto:frederic.danis@palmsource.com
-----------------------------------------------



Frederic Danis a =E9crit :
> Hello Johan,
>
> Here is a new version of the patch updated.
> Thanks for your comments.
>
>
> Fred
>
> ------------------------------------------------------------------------
>
> diff -Naur hcid.orig/dbus-adapter.c hcid.new/dbus-adapter.c
> --- hcid.orig/dbus-adapter.c	2006-10-17 17:54:10.000000000 +0200
> +++ hcid.new/dbus-adapter.c	2006-10-20 15:58:53.000000000 +0200
> @@ -25,10 +25,12 @@
>  #include <config.h>
>  #endif
>  =

> +#define _GNU_SOURCE
>  #include <stdio.h>
>  #include <errno.h>
>  #include <fcntl.h>
>  #include <unistd.h>
> +#include <time.h>
>  #include <sys/param.h>
>  #include <sys/ioctl.h>
>  #include <sys/socket.h>
> @@ -2615,6 +2617,126 @@
>  	return DBUS_HANDLER_RESULT_HANDLED;
>  }
>  =

> +struct remote_device_list_t {
> +	struct slist *list;
> +	time_t time;
> +};
> +
> +static void list_remote_devices_do_append(char *key, char *value, void *=
data)
> +{
> +	struct remote_device_list_t *param =3D data;
> +	char *address;
> +	struct tm date;
> +
> +	if (slist_find(param->list, key, (cmp_func_t) strcasecmp))
> +		return;
> +
> +	if (param->time){
> +		strptime (value, "%Y-%m-%d %H:%M:%S %Z", &date);
> +		if (difftime(mktime(&date), param->time) < 0)
> +			return;
> +	}
> +
> +	address =3D strdup(key);
> +	if (!address)
> +		return;
> +
> +	param->list =3D slist_append(param->list, address);
> +}
> +
> +static void remote_devices_do_append(void *data, void *user_data)
> +{
> +	DBusMessageIter *iter =3D user_data;
> +
> +	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &data);
> +}
> +
> +static DBusHandlerResult adapter_list_remote_devices(DBusConnection *con=
n, DBusMessage *msg, void *data)
> +{
> +	struct adapter *adapter =3D data;
> +	DBusMessageIter iter;
> +	DBusMessageIter array_iter;
> +	DBusMessage *reply;
> +	char filename[PATH_MAX + 1];
> +	struct remote_device_list_t param =3D {NULL, 0};
> +
> +	if (!dbus_message_has_signature(msg, DBUS_TYPE_INVALID_AS_STRING))
> +		return error_invalid_arguments(conn, msg);
> +
> +	/* Add Bonded devices to the list */
> +	create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "linkkeys=
");
> +	textfile_foreach(filename, list_remote_devices_do_append, &param);
> +
> +	/* Add Last Used devices to the list */
> +	create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastused=
");
> +	textfile_foreach(filename, list_remote_devices_do_append, &param);
> +
> +	/* Add Last Seen devices to the list */
> +	create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastseen=
");
> +	textfile_foreach(filename, list_remote_devices_do_append, &param);
> +
> +	reply =3D dbus_message_new_method_return(msg);
> +
> +	dbus_message_iter_init_append(reply, &iter);
> +
> +	dbus_message_iter_open_container(&iter, DBUS_TYPE_ARRAY,
> +				DBUS_TYPE_STRING_AS_STRING, &array_iter);
> +
> +	slist_foreach(param.list, remote_devices_do_append, &array_iter);
> +
> +	slist_foreach(param.list, (slist_func_t)free, NULL);
> +	slist_free(param.list);
> +
> +	dbus_message_iter_close_container(&iter, &array_iter);
> +
> +	return send_message_and_unref(conn, reply);
> +}
> +
> +static DBusHandlerResult adapter_list_recent_remote_devices(DBusConnecti=
on *conn, DBusMessage *msg, void *data)
> +{
> +	struct adapter *adapter =3D data;
> +	const char *string;
> +	struct tm date;
> +	DBusMessageIter iter;
> +	DBusMessageIter array_iter;
> +	DBusMessage *reply;
> +	char filename[PATH_MAX + 1];
> +	struct remote_device_list_t param =3D {NULL, 0};
> +
> +	if (!dbus_message_get_args(msg, NULL,
> +				DBUS_TYPE_STRING, &string,
> +				DBUS_TYPE_INVALID))
> +		return error_invalid_arguments(conn, msg);
> +
> +	if (strptime (string, "%Y-%m-%d %H:%M:%S", &date) =3D=3D NULL)
> +		return error_invalid_arguments(conn, msg);
> +	param.time =3D mktime(&date);
> +
> +	/* Add Bonded devices to the list */
> +	create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "linkkeys=
");
> +	textfile_foreach(filename, list_remote_devices_do_append, &param);
> +
> +	/* Add Last Used devices to the list */
> +	create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastused=
");
> +	textfile_foreach(filename, list_remote_devices_do_append, &param);
> +
> +	reply =3D dbus_message_new_method_return(msg);
> +
> +	dbus_message_iter_init_append(reply, &iter);
> +
> +	dbus_message_iter_open_container(&iter, DBUS_TYPE_ARRAY,
> +				DBUS_TYPE_STRING_AS_STRING, &array_iter);
> +
> +	slist_foreach(param.list, remote_devices_do_append, &array_iter);
> +
> +	slist_foreach(param.list, (slist_func_t)free, NULL);
> +	slist_free(param.list);
> +
> +	dbus_message_iter_close_container(&iter, &array_iter);
> +
> +	return send_message_and_unref(conn, reply);
> +}
> +
>  const char *major_class_str(uint32_t class)
>  {
>  	uint8_t index =3D (class >> 8) & 0x1F;
> @@ -2746,6 +2868,9 @@
>  	{ "DiscoverDevicesWithoutNameResolving",	adapter_discover_devices	},
>  	{ "CancelDiscovery",			adapter_cancel_discovery	},
>  =

> +	{ "ListRemoteDevices",				adapter_list_remote_devices		},
> +	{ "ListRecentRemoteDevices",		adapter_list_recent_remote_devices		},
> +
>  	{ NULL, NULL }
>  };
>  =

> diff -Naur hcid.orig/dbus-api.txt hcid.new/dbus-api.txt
> --- hcid.orig/dbus-api.txt	2006-10-20 18:56:14.000000000 +0200
> +++ hcid.new/dbus-api.txt	2006-10-20 18:58:33.000000000 +0200
> @@ -789,6 +789,20 @@
>  					 org.bluez.Error.InProgress
>  					 org.bluez.Error.Failed
>  =

> +		array{string} ListRemoteDevices()
> +
> +			List device addresses of all known adapters (seen, used or bonded).
> +
> +			Possible errors: none
> +
> +		array{string} ListRecentRemoteDevices(string date)
> +
> +			List device addresses of all used or bonded adapters since date.
> +
> +			date format is "YYYY-MM-DD HH:MM:SS GMT"
> +
> +			Possible errors: none
> +
>  =

>  Signals		void ModeChanged(string mode)
>  =

>   =

> ------------------------------------------------------------------------
>
> -------------------------------------------------------------------------
> Using Tomcat but need to do more? Need to support web services, security?
> Get stuff done quickly with pre-integrated technology to make your job ea=
sier
> Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo
> http://sel.as-us.falkag.net/sel?cmd=3Dlnk&kid=3D120709&bid=3D263057&dat=
=3D121642
> ------------------------------------------------------------------------
>
> _______________________________________________
> Bluez-devel mailing list
> Bluez-devel@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/bluez-devel
>   =


-------------------------------------------------------------------------
Using Tomcat but need to do more? Need to support web services, security?
Get stuff done quickly with pre-integrated technology to make your job easi=
er
Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo
http://sel.as-us.falkag.net/sel?cmd=3Dlnk&kid=3D120709&bid=3D263057&dat=3D1=
21642
_______________________________________________
Bluez-devel mailing list
Bluez-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bluez-devel

  reply	other threads:[~2006-11-07 17:28 UTC|newest]

Thread overview: 31+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-08-16 15:34 [Bluez-devel] DBus interface - determining whether a device exists Matthew Garrett
2006-08-16 20:41 ` [Bluez-devel] [PATCH] - add ConnectRemoteDevice method to dbus Matthew Garrett
2006-08-16 23:13   ` Marcel Holtmann
2006-08-16 23:16 ` [Bluez-devel] DBus interface - determining whether a device exists Marcel Holtmann
2006-08-16 21:46   ` Matthew Garrett
2006-08-17  1:21     ` Cezar Sá Espinola
2006-08-17  8:15       ` Matthew Garrett
2006-08-17 12:57         ` Marcel Holtmann
2006-08-17 11:22           ` Matthew Garrett
2006-08-17 13:51             ` Marcel Holtmann
2006-08-17 12:56     ` Marcel Holtmann
2006-08-17 11:35       ` Matthew Garrett
2006-08-17 14:04         ` Marcel Holtmann
2006-08-17 12:25           ` Matthew Garrett
2006-08-17 12:45             ` Johan Hedberg
2006-08-17 12:52               ` Matthew Garrett
2006-08-17 13:01                 ` Johan Hedberg
2006-08-17 13:03               ` Bastien Nocera
2006-08-17 18:36                 ` Marcel Holtmann
2006-08-18 12:29                   ` Frederic Danis
2006-08-18 18:06                     ` Marcel Holtmann
2006-10-18 13:37                       ` Frederic Danis
2006-10-18 14:03                         ` Johan Hedberg
2006-10-20 17:07                           ` Frederic Danis
2006-10-20 17:08                           ` Frederic Danis
2006-11-07 17:28                             ` Frederic Danis [this message]
2006-11-10  8:12                               ` Johan Hedberg
2006-11-10 16:40                                 ` Marcel Holtmann
2006-11-10 16:39                                   ` Frederic Danis
2006-11-10 19:04                                     ` Johan Hedberg
2006-08-17 18:44             ` Marcel Holtmann

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4550C24B.9080703@palmsource.com \
    --to=frederic.danis@palmsource.com \
    --cc=bluez-devel@lists.sourceforge.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox