pam_ck_connector.so is called for non-login sessions

Bug #395281 reported by Baptiste Mille-Mathias
98
This bug affects 19 people
Affects Status Importance Assigned to Milestone
gdm
Fix Released
Low
consolekit (Ubuntu)
Triaged
Low
Unassigned
gdm (Ubuntu)
Won't Fix
Low
Unassigned

Bug Description

Binary package hint: gdm

I have kerneloops installed and with new gdm from karmic the kernoops user is listed as real user in the gdm greeter.

from /etc/passwd
kernoops:x:112:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false

kerneloops version is 0.12-0ubuntu5

ProblemType: Bug
Architecture: i386
Date: Fri Jul 3 20:48:24 2009
DistroRelease: Ubuntu 9.10
Package: gdm 2.26.1-0ubuntu1
ProcEnviron:
 PATH=(custom, user)
 LANG=fr_FR.UTF-8
 SHELL=/bin/bash
ProcVersionSignature: Ubuntu 2.6.31-1.14-generic
SourcePackage: gdm
Uname: Linux 2.6.31-1-generic i686

Revision history for this message
Baptiste Mille-Mathias (bmillemathias) wrote :
Revision history for this message
James Westby (james-w) wrote :

The kerneloops package correctly creates the user as a system user,
so this seems to be a GDM issue.

I can't see what is different about the kernoops user that makes it
show up, is the only system user listed?

Thanks,

James

Changed in kerneloops (Ubuntu):
status: New → Invalid
Max Bowsher (maxb)
summary: - kernoops user is listed as real user in gdm 2.26.x
+ gdm 2.26 criteria for which users shown in greeter list are bad
Revision history for this message
Max Bowsher (maxb) wrote :

On one of my machines, the only interactive user is *not* displayed in the selection box. It sounds as if the criteria for user filtering need to be refined in both directions.

Revision history for this message
James Westby (james-w) wrote : Re: gdm 2.26 criteria for which users shown in greeter list are bad

gdm uses ck-history to find recent users that had ck sessions. We currently
end up with ck sessions for some system users, so they can appear here, which
should probably be fixed independently.

gdm then parses this and removes some users based on a hard-coded exclude
list, which doesn't include a lot of system users.

It also filters users based on a minimum UID that is lower than the min UID
for non-system users, so if someone has a lot of system users they will show
up based on that.

Suggested fix:

  * Increase the min UID
  * As users from /etc/passwd are excluded by the checks before the exclude
     check, add them to the exclude hash so that they don't enter the list via
     ck.

Thanks,

James

Revision history for this message
James Westby (james-w) wrote :

Also, the ck-history code could not add users, but just update the frequency of
existing users, avoiding this in that manner as well.

Thanks,

James

James Westby (james-w)
Changed in gdm (Ubuntu):
assignee: nobody → Ubuntu Desktop Bugs (desktop-bugs)
importance: Undecided → Low
status: New → Triaged
Changed in gdm:
status: Unknown → New
Revision history for this message
Max Bowsher (maxb) wrote :

It appears that the reason I saw no users was because some consolekit related thing was taking lots of time to process, blocking the list population. On a second boot, the list initially appeared unpopulated, but was populated with relevant users after about 5 seconds. (Point of interest: ck-history was still running and consuming lots of CPU for several seconds *after* login.)

Martin Pitt (pitti)
Changed in gdm (Ubuntu):
assignee: Ubuntu Desktop Bugs (desktop-bugs) → Martin Pitt (pitti)
Martin Pitt (pitti)
Changed in gdm (Ubuntu):
status: Triaged → Fix Committed
Revision history for this message
Launchpad Janitor (janitor) wrote :

This bug was fixed in the package gdm - 2.26.1-0ubuntu3

---------------
gdm (2.26.1-0ubuntu3) karmic; urgency=low

  * Add 03_hide_system_users.patch: Do not show system users in the "frequent
    users" list. (LP: #395281)
  * debian/rules: Call dh_installinit with --no-scripts, to avoid restarting
    gdm (and killing your X session) during upgrade. The prerm/postinst
    scripts already have code to reload gdm if appropriate. Unfortunately this
    doesn't help to fix the upgrade from 0ubuntu2, its prerm already kills it.
    (LP: #395302) This also fixes the "locks session and spawns a second X
    server" issue on upgrades from Jaunty. (LP: #395313)
  * Drop 16_correct_customconf_naming.patch: Upstream uses
    and installs /etc/gdm/custom.conf, so gdm also needs to read this. Add
    debian/gdm.preinst to migrate the old name to the new name on upgrades.
    (LP: #395861)
  * 02_dont_force_us_keyboard.patch: Don't return NULL in
    get_default_layout(), but return an empty string and explicitly check this
    when setting $GDM_KEYBOARD_LAYOUT. With NULL, gdm trips over an assertion
    check. (LP: #395595)

 -- Martin Pitt <email address hidden> Mon, 06 Jul 2009 16:04:25 +0200

Changed in gdm (Ubuntu):
status: Fix Committed → Fix Released
Revision history for this message
Id2ndR (id2ndr) wrote :

I'm not sure to understand correctly of the information above so here is my question : is it possible to customise the user that should not be shown in karmic without changing their uid to a value lower than 1000 ?

Revision history for this message
Id2ndR (id2ndr) wrote :

I think I have the answer : this is the following debian bug http://debathena.mit.edu/trac/ticket/429

Changed in gdm:
importance: Unknown → Low
Changed in gdm:
status: New → Fix Released
Revision history for this message
Chad Miller (cmiller) wrote :

I can't seem to open/Confirm this for Natty only.

I suspect it's the same problem, for 2.32.0-0ubuntu1 in Natty.

Changed in gdm (Ubuntu):
status: Fix Released → Confirmed
Revision history for this message
Chad Miller (cmiller) wrote :

My /etc/gdm/custom.conf is empty, aside from section headers and <<EOF

[greeter]

DefaultFace=

GlobalFaceDir=/usr/share/pixmaps/
EOF

My gdm.conf.dpkg-bak has "MinimalUID=1000" in it's [greeter] section, FWIW.

Daemon users showing up are rabbitmq (uid 133) and couchdb (uid 127).

Revision history for this message
Chad Miller (cmiller) wrote :

$ ck-history --frequent
cmiller 279
rabbitmq 60
nobody 55
maryelle 34
gdm 33
couchdb 27
guest 3
root 1

Revision history for this message
Martin Pitt (pitti) wrote :

This is really a bug in the libpam-ck-connector PAM integration. It shouldn't be in common-session, but in /etc/pam.d/login only.
/usr/share/pam-configs/consolekit already says "Session-Interactive-Only: yes", so pam-auth-update shoudln't put it in common-session in the first place (as this is also called for cron and the like)?

If pam-auth-update can't put stuff into /etc/pam.d/login, then we need to work around this in consolekit itself and filter out system users.

affects: kerneloops (Ubuntu) → consolekit (Ubuntu)
Changed in consolekit (Ubuntu):
status: Invalid → Triaged
Revision history for this message
Martin Pitt (pitti) wrote :

Let's not continue to hack around this in gdm any more, it's just wrong, and a waste of IO, cycles, and power to always run consolekit on every cron or at session.

Changed in consolekit (Ubuntu):
status: Triaged → Won't Fix
status: Won't Fix → Triaged
Changed in gdm (Ubuntu):
status: Confirmed → Won't Fix
Changed in consolekit (Ubuntu):
assignee: nobody → Martin Pitt (pitti)
Changed in gdm (Ubuntu):
assignee: Martin Pitt (pitti) → nobody
summary: - gdm 2.26 criteria for which users shown in greeter list are bad
+ pam_ck_connector.so is called for non-login sessions
Revision history for this message
Steve Langasek (vorlon) wrote : Re: [Bug 395281] Re: gdm 2.26 criteria for which users shown in greeter list are bad

8On Fri, Dec 10, 2010 at 03:27:36PM -0000, Martin Pitt wrote:
> This is really a bug in the libpam-ck-connector PAM integration. It shouldn't be in common-session, but in /etc/pam.d/login only.
> /usr/share/pam-configs/consolekit already says "Session-Interactive-Only:
> yes", so pam-auth-update shoudln't put it in common-session in the first
> place (as this is also called for cron and the like)?

No, common-session is the file for "interactive" services; "noninteractive"
services need to include common-session-noninteractive instead of
common-session, and any noninteractive service that is including
common-session is buggy.

> If pam-auth-update can't put stuff into /etc/pam.d/login

It does not, no. But that should be immaterial; if these extra entries are
coming from cron, that was fixed in karmic.

OTOH, if they're coming from an init script that's calling 'su', that's a
buggy init script; init scripts should use start-stop-daemon, not su.

Maybe login is the *only* service that pam_ck_connector should be applied
to for other reasons because the distinction between login and non-login
*interactive* sessions matters, but I don't think ck-history should be a
reason for that.

--
Steve Langasek Give me a lever long enough and a Free OS
Debian Developer to set it on, and I can move the world.
Ubuntu Developer http://www.debian.org/
<email address hidden> <email address hidden>

Revision history for this message
Martin Pitt (pitti) wrote :

Steve,

thanks for the clarification. So it seems rabbitmq and couchdb are cases of using "su". I'm a bit undecided whether "login" should really be the only service for pam-ck. It's the main use case for e. g. giving you access to your sound card if you login through a VT, but it's also nice to get that if you do su - otheruser. Ideally we'd only count this as an user session if this actually called the login shell, but that's outside of PAM.

So I think the best course of action is to fix CK to ignore system users and also fix the couchdb/rabbitmq init scripts to not use su.

Revision history for this message
Chad Miller (cmiller) wrote :

Also in my /etc/init.d are ejabberd and pgbouncer using "su".

Revision history for this message
Max Bowsher (maxb) wrote :

It's far from uncommon to use su in startup scripts - even ones crafted by local sysadmins. I don't think defining 'su' to start a CK session is the right thing to do.

Case in point: I crafted a local upstart job to run a java rmiregistry on my machine, and I su-ed it because it has no need to run as root, and no user-changing capability of its own. Later, I started getting spurious "there is another user logged in" warnings when shutting down my computer. It took some considerable head-scratching before I realized the non-obvious linkage here, and then only because I had some small prior experience with CK oddities.

Revision history for this message
Steve Langasek (vorlon) wrote : Re: [Bug 395281] Re: pam_ck_connector.so is called for non-login sessions

On Tue, Dec 14, 2010 at 01:22:22AM -0000, Max Bowsher wrote:
> It's far from uncommon to use su in startup scripts - even ones crafted
> by local sysadmins. I don't think defining 'su' to start a CK session is
> the right thing to do.

su *is* the wrong tool to use for starting services, because su *is* defined
to start PAM sessions. pam_ck_connector is not the only PAM module that may
get called by su that shouldn't be called when starting a service - such as
pam_limits, to pick one commented out example from /etc/pam.d/su itself.

That local sysadmins *may* make uninformed choices when writing their init
scripts doesn't change the fact that you don't want to start a PAM session
from an init script, and the adverse interactions with pam_ck_connect are
only one symptom of this.

--
Steve Langasek Give me a lever long enough and a Free OS
Debian Developer to set it on, and I can move the world.
Ubuntu Developer http://www.debian.org/
<email address hidden> <email address hidden>

Changed in gdm:
status: Fix Released → Confirmed
Revision history for this message
Sebastien Bacher (seb128) wrote :

that's still an issue, see bug #699930

Changed in gdm:
status: Confirmed → Fix Released
Revision history for this message
Sampo Savolainen (v2) wrote :

This bug affects 11.10 and rabbitmq. The computer will not shutdown via lightdm or gnome session because lightdm thinks rabbitmq is still running. It's worth noting I don't use the ubuntu provided rabbitmq packages. Instead I use the packages from rabbitmq.com . I haven't tested this issue with the ubuntu rabbitmq package.

Revision history for this message
Simon MacMullen (simon-macmullen) wrote :

Steve Langasek said:
> su *is* the wrong tool to use for starting services, because su *is* defined
> to start PAM sessions.

Gosh, I wish I'd seen that a year ago :)

I hope this is a reasonable place to ask the following question:

So if I can't use su, what can I use? I want to start the rabbit process as the "rabbitmq" user, and Erlang programs can't easily setuid(3). I'm not aware of an alternative to su, but I could well be ignorant.

Revision history for this message
Simon MacMullen (simon-macmullen) wrote :

Gah, I can't read. start-stop-daemon.

Revision history for this message
Martin Pitt (pitti) wrote :

Simon MacMullen [2011-12-05 10:58 -0000]:
> So if I can't use su, what can I use? I want to start the rabbit process
> as the "rabbitmq" user, and Erlang programs can't easily setuid(3). I'm
> not aware of an alternative to su, but I could well be ignorant.

In the Debian world we use start-stop-daemon with the -c/-g options,
see the manpage.

Thanks, Martin
--
Martin Pitt | http://www.piware.de
Ubuntu Developer (www.ubuntu.com) | Debian Developer (www.debian.org)

Martin Pitt (pitti)
Changed in consolekit (Ubuntu):
assignee: Martin Pitt (pitti) → nobody
importance: Undecided → Low
To post a comment you must log in.
This report contains Public information  
Everyone can see this information.

Other bug subscribers

Remote bug watches

Bug watches keep track of this bug in other bug trackers.