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, ¶m);
> +
> + /* Add Last Used devices to the list */
> + create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastused=
");
> + textfile_foreach(filename, list_remote_devices_do_append, ¶m);
> +
> + /* Add Last Seen devices to the list */
> + create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastseen=
");
> + textfile_foreach(filename, list_remote_devices_do_append, ¶m);
> +
> + 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, ¶m);
> +
> + /* Add Last Used devices to the list */
> + create_name(filename, PATH_MAX, STORAGEDIR, adapter->address, "lastused=
");
> + textfile_foreach(filename, list_remote_devices_do_append, ¶m);
> +
> + 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
next prev parent 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