chiark / gitweb /
pam_logind: skip leading /dev/ from PAM_TTY field before passing it on
authorLennart Poettering <lennart@poettering.net>
Wed, 9 Aug 2017 17:04:36 +0000 (19:04 +0200)
committerSven Eden <yamakuzure@gmx.net>
Wed, 9 Aug 2017 17:04:36 +0000 (19:04 +0200)
Apparently, PAM documents that the PAM_TTY should come with a /dev
prefix, but we don't expect it so far, except that Wayland ends up
setting it after all, the way the docs suggest. Hence, let's simply drop
the /dev prefix if it is there.

Fixes: #6516
src/login/pam_elogind.c

index 3af3487f5f1c60c8cb62f2cb06c53631a043746f..5300e218b8a21d652ce9a0eb48154a5367a94ce5 100644 (file)
@@ -46,6 +46,7 @@
 #include "strv.h"
 #include "terminal-util.h"
 #include "util.h"
+#include "path-util.h"
 
 static int parse_argv(
                 pam_handle_t *handle,
@@ -339,7 +340,9 @@ _public_ PAM_EXTERN int pam_sm_open_session(
                 type ="tty";
                 class = "user";
                 tty = NULL;
-        }
+        } else
+                /* Chop off leading /dev prefix that some clients specify, but others do not. */
+                tty = skip_dev_prefix(tty);
 
         /* If this fails vtnr will be 0, that's intended */
         if (!isempty(cvtnr))