Re: SELinux errors with pam_faillock

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



I think the bigger issue with your question on sudo and newrole is
what have you done to get into the system without already creating
faillog files for the current user. Both sudo and newrole are only
authenticating the existing user. There is a problem in su.if that it
needs manage instead of rw since you are changing to a different user
which may not yet have a faillog entry as I would understand this
process. Also, there is also a missing block to read the cracklib
dictionaries in the sudo.if file.

On Fri, Apr 26, 2013 at 10:54 AM, Andy Ruch <adruch2002@xxxxxxxxx> wrote:
>
>
>>________________________________
>> From: Christopher J. PeBenito <cpebenito@xxxxxxxxxx>
>>To: Andy Ruch <adruch2002@xxxxxxxxx>
>>Cc: SELinux ML <selinux@xxxxxxxxxxxxx>
>>Sent: Friday, April 26, 2013 5:56 AM
>>Subject: Re: SELinux errors with pam_faillock
>>
>>
>>On 04/25/13 17:35, Andy Ruch wrote:
>>> I'm receiving some SELinux errors related to the pam_faillock module. I'm running RHEL 6.3 with a custom policy based on the reference policy.
>>>
>>> When a user enters an incorrect password, the pam faillock module will track it with a file in /var/run/faillock/<user>. This is being applied whenever the user enters their password (i.e. console login, newrole, sudo). Everything works appropriately for the console login. For newrole and sudo, I'm getting errors when the /var/run/faillock/<user> file is trying to be created. Basically, newrole_t and <role>_sudo_t don't have permission to create files in a faillog_t dir.
>>>
>>> I found a rule in 'selinuxutil.te' allowing newrole_t to read/write to faillog: "auth_rw_faillog(newrole_t)". However, this rule only allows writing if the file already exists. It doesn't address if the faillock file needs to be created.
>>
>>faillog_t was really only oriented towards /var/log/faillog only.  It might make more sense to label it auth_cache_t, though it looks like you'll need to add perms to newrole.
>
>
> This was how it was defined in the reference policy, but it seems to make sense to change it.
>
>>
>>> I'm able to address the issues with the following rules:
>>>
>>> # Note that these rules would be applied in the sudo interface to support all sudo types
>>> create_files_pattern( sysadm_sudo_t, faillog_t, faillog_t )
>>> setattr_files_pattern( sysadm_sudo_t, faillog_t, faillog_t )
>>> allow sysadm_sudo_t_t self:capability:chown;
>>>
>>> create_files_pattern( newrole_t, faillog_t, faillog_t )
>>> setattr_files_pattern( newrole_t, faillog_t, faillog_t )
>>> allow newrole_t self:capability:chown;
>>>
>>> Is this the correct solution? Or should a transition be happening when faillock executes?
>>
>>Is there an exec() to transition on?  Pam modules are shared libraries that are dlopened into the process, so there's typically no exec().
>
> I'm sure you're right. I'm somewhat new to SELinux so I wasn't sure if there was something else I was missing. Primarily, I wasn't sure if it was appropriate to grant create/write permissions for these faillock files to the sudo type for a role.
>
>
>>
>>--
>>Chris PeBenito
>>Tresys Technology, LLC
>>www.tresys.com | oss.tresys.com
>>
>>--
>>This message was distributed to subscribers of the selinux mailing list.
>>If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
>>the words "unsubscribe selinux" without quotes as the message.
>>
>>
>>
>
>
> --
> This message was distributed to subscribers of the selinux mailing list.
> If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
> the words "unsubscribe selinux" without quotes as the message.


--
This message was distributed to subscribers of the selinux mailing list.
If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
the words "unsubscribe selinux" without quotes as the message.




[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux