diff options
author | Matthew Monaco <matthew.monaco@0x01b.net> | 2012-12-24 06:25:58 -0700 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2012-12-24 19:17:48 +0100 |
commit | 485507b8c031e0c75f43c4b4fce5a0082a812fbb (patch) | |
tree | b9fc431bfb4773349c0f51a7aabd155353538ff8 | |
parent | a78a8c43376dde67a98ca275f4d917a71f48e672 (diff) |
pam_systemd: new option for the session class
-rw-r--r-- | man/pam_systemd.xml | 9 | ||||
-rw-r--r-- | src/login/pam-module.c | 12 |
2 files changed, 19 insertions, 2 deletions
diff --git a/man/pam_systemd.xml b/man/pam_systemd.xml index 2d2f191487..600bfd71b4 100644 --- a/man/pam_systemd.xml +++ b/man/pam_systemd.xml @@ -194,6 +194,15 @@ </varlistentry> <varlistentry> + <term><option>class=</option></term> + + <listitem><para>Takes a string + argument which sets the session class. + The XDG_SESSION_CLASS environmental variable + takes precedence.</para></listitem> + </varlistentry> + + <varlistentry> <term><option>debug=</option></term> <listitem><para>Takes a boolean diff --git a/src/login/pam-module.c b/src/login/pam-module.c index e6764a197a..88b0ef9e45 100644 --- a/src/login/pam-module.c +++ b/src/login/pam-module.c @@ -49,6 +49,7 @@ static int parse_argv(pam_handle_t *handle, bool *kill_processes, char ***kill_only_users, char ***kill_exclude_users, + const char **class, bool *debug) { unsigned i; @@ -135,6 +136,11 @@ static int parse_argv(pam_handle_t *handle, *kill_exclude_users = l; } + } else if (startswith(argv[i], "class=")) { + + if (class) + *class = argv[i] + 6; + } else if (startswith(argv[i], "debug=")) { if ((k = parse_boolean(argv[i] + 6)) < 0) { pam_syslog(handle, LOG_ERR, "Failed to parse debug= argument."); @@ -322,7 +328,7 @@ _public_ PAM_EXTERN int pam_sm_open_session( struct passwd *pw; bool kill_processes = false, debug = false; - const char *username, *id, *object_path, *runtime_path, *service = NULL, *tty = NULL, *display = NULL, *remote_user = NULL, *remote_host = NULL, *seat = NULL, *type = NULL, *class, *cvtnr = NULL; + const char *username, *id, *object_path, *runtime_path, *service = NULL, *tty = NULL, *display = NULL, *remote_user = NULL, *remote_host = NULL, *seat = NULL, *type = NULL, *class = NULL, *class_pam = NULL, *cvtnr = NULL; char **controllers = NULL, **reset_controllers = NULL, **kill_only_users = NULL, **kill_exclude_users = NULL; DBusError error; uint32_t uid, pid; @@ -349,7 +355,7 @@ _public_ PAM_EXTERN int pam_sm_open_session( argc, argv, &controllers, &reset_controllers, &kill_processes, &kill_only_users, &kill_exclude_users, - &debug) < 0) { + &class_pam, &debug) < 0) { r = PAM_SESSION_ERR; goto finish; } @@ -485,6 +491,8 @@ _public_ PAM_EXTERN int pam_sm_open_session( if (isempty(class)) class = getenv("XDG_SESSION_CLASS"); if (isempty(class)) + class = class_pam; + if (isempty(class)) class = "user"; remote = !isempty(remote_host) && |