aboutsummaryrefslogtreecommitdiff
path: root/backend/session
diff options
context:
space:
mode:
authorScott Anderson <scott@anderso.nz>2019-05-22 23:42:46 +0000
committerGitHub <noreply@github.com>2019-05-22 23:42:46 +0000
commit0ab1bb623e58bafef315c9eb33a430e72d40408a (patch)
treeebee5e175d7127aa5f7b2ca1d3219ef0c391a885 /backend/session
parentaa39dbd1e7a3fe9b6bcb6bcc6897d90b0b5fda73 (diff)
parent151b7d1d940a4dc732f23bbb7535f5c3a13c7657 (diff)
Merge pull request #1705 from rindeal/patch-2
session/logind: check for XDG_SESSION_ID first
Diffstat (limited to 'backend/session')
-rw-r--r--backend/session/logind.c17
1 files changed, 14 insertions, 3 deletions
diff --git a/backend/session/logind.c b/backend/session/logind.c
index 276e2c3f..c7fb24c0 100644
--- a/backend/session/logind.c
+++ b/backend/session/logind.c
@@ -538,15 +538,26 @@ static bool get_display_session(char **session_id) {
assert(session_id != NULL);
int ret;
+ char *type = NULL;
+ char *state = NULL;
+ char *xdg_session_id = getenv("XDG_SESSION_ID");
+
+ if (xdg_session_id) {
+ // This just checks whether the supplied session ID is valid
+ if (sd_session_is_active(xdg_session_id) < 0) {
+ wlr_log(WLR_ERROR, "Invalid XDG_SESSION_ID: '%s'", xdg_session_id);
+ goto error;
+ }
+ *session_id = strdup(xdg_session_id);
+ return true;
+ }
+
// If there's a session active for the current process then just use that
ret = sd_pid_get_session(getpid(), session_id);
if (ret == 0) {
return true;
}
- char *type = NULL;
- char *state = NULL;
-
// Find any active sessions for the user if the process isn't part of an
// active session itself
ret = sd_uid_get_display(getuid(), session_id);