On Tue, Jun 13, 2017 at 10:43 AM, Stephen Smalley <sds@xxxxxxxxxxxxx> wrote: > On Tue, 2017-06-13 at 09:37 +0200, Laurent Bigonville wrote: >> Hi, >> >> Currently the dbus-daemon is not returning anything when asked about >> its >> own security context (using GetConnectionSELinuxSecurityContext or >> GetConnectionCredentials methods). This cause some issues[0] with >> systemd now that it's enforcing the policy for user sessions again. >> >> I already made a patch that has been merged[1][2] upstream in the >> GetConnectionSELinuxSecurityContext case and it now returns the >> SELinux >> context of the dbus-daemon process itself. >> >> For the GetConnectionCredentials case, upstream wanted a generic way >> of >> getting the security label and went the way of using SO_PEERSEC on a >> socket connected to itself. >> >> But for some reasons it's always returning unlabeled_t. Note that >> the >> same value is returned by the getpeercon() function as well. >> >> I've made a small test case (see attached file) and tested it on >> both >> debian and RHEL7. >> >> Is this somehow expected? Is this a bug? >> >> Cheers, >> >> Laurent Bigonville >> >> [0]https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=864221 >> [1]https://bugs.freedesktop.org/show_bug.cgi?id=101315 >> [2] https://phabricator.freedesktop.org/rDBUSdcf02f80656d > > SO_PEERSEC has never been supported for socketpair()-created sockets. > To do so would require a new LSM hook called by unix_socketpair() to > set the peer SIDs for the two sockets. In the absence of such a hook, > the peer SIDs are left with their initial values (the unlabeled SID), > and thus SO_PEERSEC returns the unlabeled context for both. That's why > you see the current behavior. > > It would be easy enough to implement such a hook (and perhaps we > should), but the more fundamental question is whether SO_PEERSEC makes > sense for socketpair()-created sockets and what does it actually mean. Just to weigh in on this issue, the meaning is exactly as Stephen said at the end of his email: "SO_PEERSEC returns the context of the peer socket". Based on my understanding of how socketpair() is typically used this would be confusing for the majority of applications, sticking with the current (unlabeled peer) behavior seems the best option. -- paul moore www.paul-moore.com