Don't trust SNI names, fixes #1274

If an item doesn't have a well-formed name, it will not be added to the
tray.
This commit is contained in:
Calvin Lee 2017-07-13 07:47:21 -07:00
parent 13ed84e886
commit 62223e8fbb
3 changed files with 16 additions and 5 deletions

View File

@ -28,6 +28,7 @@ void sni_icon_ref_free(struct sni_icon_ref *sni_ref);
/** /**
* Will return a new item and get its icon. (see warning below) * Will return a new item and get its icon. (see warning below)
* May return `NULL` if `name` is not valid.
*/ */
struct StatusNotifierItem *sni_create(const char *name); struct StatusNotifierItem *sni_create(const char *name);

View File

@ -413,6 +413,12 @@ static void get_unique_name(struct StatusNotifierItem *item) {
} }
struct StatusNotifierItem *sni_create(const char *name) { struct StatusNotifierItem *sni_create(const char *name) {
// Make sure `name` is well formed
if (!dbus_validate_bus_name(name, NULL)) {
sway_log(L_INFO, "Name (%s) is not a bus name. We cannot create an item.", name);
return NULL;
}
struct StatusNotifierItem *item = malloc(sizeof(struct StatusNotifierItem)); struct StatusNotifierItem *item = malloc(sizeof(struct StatusNotifierItem));
item->name = strdup(name); item->name = strdup(name);
item->unique_name = NULL; item->unique_name = NULL;

View File

@ -90,9 +90,11 @@ static void get_items_reply(DBusPendingCall *pending, void *_data) {
struct StatusNotifierItem *item = sni_create(name); struct StatusNotifierItem *item = sni_create(name);
sway_log(L_DEBUG, "Item registered with host: %s", name); if (item) {
list_add(tray->items, item); sway_log(L_DEBUG, "Item registered with host: %s", name);
dirty = true; list_add(tray->items, item);
dirty = true;
}
} }
bail: bail:
@ -141,8 +143,10 @@ static DBusHandlerResult signal_handler(DBusConnection *connection,
if (list_seq_find(tray->items, sni_str_cmp, name) == -1) { if (list_seq_find(tray->items, sni_str_cmp, name) == -1) {
struct StatusNotifierItem *item = sni_create(name); struct StatusNotifierItem *item = sni_create(name);
list_add(tray->items, item); if (item) {
dirty = true; list_add(tray->items, item);
dirty = true;
}
} }
return DBUS_HANDLER_RESULT_HANDLED; return DBUS_HANDLER_RESULT_HANDLED;