mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-04 13:30:12 -05:00
access: make access property configurable
Just set the value of access.force into pipewire.access so that the session manager can deal with it.
This commit is contained in:
parent
33d7b6ea43
commit
f2c1ab6069
1 changed files with 4 additions and 5 deletions
|
|
@ -126,7 +126,7 @@ context_check_access(void *data, struct pw_impl_client *client)
|
||||||
struct pw_permission permissions[1];
|
struct pw_permission permissions[1];
|
||||||
struct spa_dict_item items[2];
|
struct spa_dict_item items[2];
|
||||||
const struct pw_properties *props;
|
const struct pw_properties *props;
|
||||||
const char *str;
|
const char *str, *access;
|
||||||
int pid, res;
|
int pid, res;
|
||||||
|
|
||||||
pid = -EINVAL;
|
pid = -EINVAL;
|
||||||
|
|
@ -176,10 +176,10 @@ context_check_access(void *data, struct pw_impl_client *client)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (impl->properties &&
|
if (impl->properties &&
|
||||||
(str = pw_properties_get(impl->properties, "access.force")) != NULL &&
|
(access = pw_properties_get(impl->properties, "access.force")) != NULL) {
|
||||||
strcmp(str, "flatpak") == 0) {
|
|
||||||
res = 1;
|
res = 1;
|
||||||
} else {
|
} else {
|
||||||
|
access = "flatpak";
|
||||||
res = check_flatpak(client, pid);
|
res = check_flatpak(client, pid);
|
||||||
}
|
}
|
||||||
if (res != 0) {
|
if (res != 0) {
|
||||||
|
|
@ -192,10 +192,9 @@ context_check_access(void *data, struct pw_impl_client *client)
|
||||||
else if (res > 0) {
|
else if (res > 0) {
|
||||||
pw_log_debug("module %p: sandboxed client %p added", impl, client);
|
pw_log_debug("module %p: sandboxed client %p added", impl, client);
|
||||||
}
|
}
|
||||||
items[0] = SPA_DICT_ITEM_INIT(PW_KEY_ACCESS, "flatpak");
|
items[0] = SPA_DICT_ITEM_INIT(PW_KEY_ACCESS, access);
|
||||||
goto wait_permissions;
|
goto wait_permissions;
|
||||||
}
|
}
|
||||||
|
|
||||||
granted:
|
granted:
|
||||||
pw_log_debug("module %p: client %p access granted", impl, client);
|
pw_log_debug("module %p: client %p access granted", impl, client);
|
||||||
permissions[0] = PW_PERMISSION_INIT(PW_ID_ANY, PW_PERM_RWX);
|
permissions[0] = PW_PERMISSION_INIT(PW_ID_ANY, PW_PERM_RWX);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue