diff --git a/doc/advertising-api.txt b/doc/advertising-api.txt
index 65f1331..c9bc9a1 100644
--- a/doc/advertising-api.txt
+++ b/doc/advertising-api.txt
Possible values: as found on
LEAdvertisingManager.SupportedIncludes
+ string LocalName
+
+ Local name to be used in the advertising report. If the
+ string is too big to fit into the packet it will be
+ truncated.
+
+ If this property is available 'local-name' cannot be
+ present in the Includes.
+
LE Advertising Manager hierarchy
================================
diff --git a/src/advertising.c b/src/advertising.c
index 61b17e4..e452070 100644
--- a/src/advertising.c
+++ b/src/advertising.c
struct btd_adv_manager *manager;
char *owner;
char *path;
+ char *name;
GDBusClient *client;
GDBusProxy *proxy;
DBusMessage *reg;
if (client->path)
g_free(client->path);
+ free(client->name);
free(client);
}
return true;
}
+static bool parse_local_name(DBusMessageIter *iter,
+ struct btd_adv_client *client)
+{
+ const char *name;
+
+ if (dbus_message_iter_get_arg_type(iter) != DBUS_TYPE_STRING)
+ return false;
+
+ if (client->flags & MGMT_ADV_FLAG_LOCAL_NAME) {
+ error("Local name already included");
+ return false;
+ }
+
+ dbus_message_iter_get_basic(iter, &name);
+
+ client->name = strdup(name);
+
+ return true;
+}
+
static struct adv_parser {
const char *name;
bool (*func)(DBusMessageIter *iter, struct btd_adv_client *client);
{ "ManufacturerData", parse_manufacturer_data },
{ "ServiceData", parse_service_data },
{ "Includes", parse_includes },
+ { "LocalName", parse_local_name },
{ },
};
struct btd_adv_manager *manager = client->manager;
const char *name;
- if (!(*flags & MGMT_ADV_FLAG_LOCAL_NAME)) {
+ if (!(*flags & MGMT_ADV_FLAG_LOCAL_NAME) && !client->name) {
*len = 0;
return NULL;
}
*flags &= ~MGMT_ADV_FLAG_LOCAL_NAME;
- name = btd_adapter_get_name(manager->adapter);
+ name = client->name;
+ if (!name)
+ name = btd_adapter_get_name(manager->adapter);
bt_ad_add_name(client->scan, name);