diff options
author | Drew DeVault <sir@cmpwn.com> | 2016-12-01 22:03:36 -0500 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2016-12-01 22:03:36 -0500 |
commit | ffdbb9d05077db2a44ab0f307b09d6bdbd1cab27 (patch) | |
tree | 065df35b6cb2a263a6e7531fa2b71de0a5919c92 | |
parent | dc4b57c868662e76dc4363eca6ddd0d73284eb72 (diff) | |
download | sway-ffdbb9d05077db2a44ab0f307b09d6bdbd1cab27.tar.xz |
Enforce fullscreen permissions
-rw-r--r-- | sway/handlers.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/sway/handlers.c b/sway/handlers.c index 2235bc8b..24784330 100644 --- a/sway/handlers.c +++ b/sway/handlers.c @@ -21,6 +21,7 @@ #include "sway/criteria.h" #include "sway/ipc-server.h" #include "sway/input.h" +#include "sway/security.h" #include "list.h" #include "stringop.h" #include "log.h" @@ -516,8 +517,13 @@ static void handle_view_geometry_request(wlc_handle handle, const struct wlc_geo static void handle_view_state_request(wlc_handle view, enum wlc_view_state_bit state, bool toggle) { swayc_t *c = swayc_by_handle(view); + pid_t pid = wlc_view_get_pid(view); switch (state) { case WLC_BIT_FULLSCREEN: + if (!(get_feature_policy(pid) & FEATURE_FULLSCREEN)) { + sway_log(L_INFO, "Denying fullscreen to %d (%s)", pid, c->name); + break; + } // i3 just lets it become fullscreen wlc_view_set_state(view, state, toggle); if (c) { |