diff options
author | Manoj Srivastava <srivasta@debian.org> | 2014-02-09 16:09:49 +0000 |
---|---|---|
committer | Colin Watson <cjwatson@debian.org> | 2014-10-07 14:26:47 +0100 |
commit | c9638aa44d787849cea1ae273f0908c6313fd19b (patch) | |
tree | 6b8681822821aad0dcc92575411f0e6fdfb994bf /sshpty.c | |
parent | b25d6dd3b6b5a2cb93723586c56d6fa0277ea56a (diff) |
Handle SELinux authorisation roles
Rejected upstream due to discomfort with magic usernames; a better approach
will need an SSH protocol change. In the meantime, this came from Debian's
SELinux maintainer, so we'll keep it until we have something better.
Bug: https://bugzilla.mindrot.org/show_bug.cgi?id=1641
Bug-Debian: http://bugs.debian.org/394795
Last-Update: 2013-09-14
Patch-Name: selinux-role.patch
Diffstat (limited to 'sshpty.c')
-rw-r--r-- | sshpty.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -187,7 +187,7 @@ pty_change_window_size(int ptyfd, u_int row, u_int col, | |||
187 | } | 187 | } |
188 | 188 | ||
189 | void | 189 | void |
190 | pty_setowner(struct passwd *pw, const char *tty) | 190 | pty_setowner(struct passwd *pw, const char *tty, const char *role) |
191 | { | 191 | { |
192 | struct group *grp; | 192 | struct group *grp; |
193 | gid_t gid; | 193 | gid_t gid; |
@@ -214,7 +214,7 @@ pty_setowner(struct passwd *pw, const char *tty) | |||
214 | strerror(errno)); | 214 | strerror(errno)); |
215 | 215 | ||
216 | #ifdef WITH_SELINUX | 216 | #ifdef WITH_SELINUX |
217 | ssh_selinux_setup_pty(pw->pw_name, tty); | 217 | ssh_selinux_setup_pty(pw->pw_name, tty, role); |
218 | #endif | 218 | #endif |
219 | 219 | ||
220 | if (st.st_uid != pw->pw_uid || st.st_gid != gid) { | 220 | if (st.st_uid != pw->pw_uid || st.st_gid != gid) { |