linux-nfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Simo Sorce <simo@redhat.com>
To: andros@netapp.com
Cc: steved@redhat.com, linux-nfs@vger.kernel.org
Subject: Re: [PATCH Version 2 0/3] GSSD: Use gss-ctx keys and gsskeyd to sync Kerberos credentials and kernel gss_contexts.
Date: Tue, 22 Oct 2013 11:02:28 -0400	[thread overview]
Message-ID: <1382454148.9794.72.camel@willson.li.ssimo.org> (raw)
In-Reply-To: <1382451757-3032-1-git-send-email-andros@netapp.com>

On Tue, 2013-10-22 at 10:22 -0400, andros@netapp.com wrote:
> From: Andy Adamson <andros@netapp.com>
> 
> This is an RFC patchset, which will be used for testing.
> 
> This patchset requires the "SUNRPC: destroy gss_cred and context on Kerberos credential destruction" kernel patchset.
> 
> We need to do a lot of testing to ensure that once kdestroy and gss-ctx
> gss_user_destroy is called, all existing buffered
> writes using the 'destroyed gss credential + context' are serviced.
> 
> Differences from version 1:
> 
> - moved from nfstgt_login and nfstgt_logout to gsskeyd.
> - gsskeyd automatically creates gss-ctx key on kinit and destroys the gss-ctx
> key on kdestroy.
> 
> gsskeyd will need to act differently for different krb5 credential caches.

Why ?

> For example, some versions of gssd store FILE credentials in FILE:/tmp/krb5cc_<UID>
> while this code, written for fedora 19 uses FILE:/run/user/<UID>/krb5cc/tgt.

This is incorrect, Fedora 19 use DIR type ccaches, so you should
reference a cache withing the dir type, which will notmally be something
like: DIR:/run/user/<uidnumber>/krb5cc for the whole collection or
DIR::/run/user/<uidnumber>/krb5cc/txtXXXXXX for the sepcific cache.

However note that due to issues with DIR type caches we are moving to a
new KEYRING based type of cache in F20, so assuming any specific type of
cache is a dead start.

> As Trond suggested, if we keep gsskeyd separate from gssd, we could set up a
> configuration file along the lines of the keytools' request-key.conf file to
> allow both NFS and CIFS (and other filesystems) to install plugin handlers
> for kinit/kdestroy events.

Given in many cases (the desirable ones at least) kerberos credentials
are not inited via kinit, but rather by things like pam_krb5, sssd, or
directly imported via sshd, I am trying to understand how you are going
to address the majority of these cases.

Should users put gsskeyd in their .profile/.bashrc files or something ?

> Else, we could have gssd be the process to poll inotify (given
> that it already polls rpc_pipefs) and then just have it fork off the
> subprocess if and when it sees an interesting event.

What is an 'interesting' event ?

> We need to investigate how this works when the kernel keyring is used for
> Kerberos credentials. I believe that in this case gsskeyd can add the gss-ctx
> key to the kerberos keyring, and it will get destroyed along with all other
> keys at kdestroy.

Is there any reason why you are doing this work with an utility that is
separate from gssd or libkrb5 ?

I think the only sensible way to handle something like this is by adding
support directly in libkrb5, I do not see something external ever
working reliably.
I am not against it for testing purposes, but then does it need to be
committed to nfs-utils ?

Simo.

> Andy Adamson (2):
>   GSSD add cc_name to upcall
>   ANDROS: update gsskeyd to use new /run/user/UID/krb5cc/tgt cache file
> 
> Weston Andros Adamson (1):
>   WIP: Add gsskeyd
> 
>  configure.ac            |   1 +
>  utils/Makefile.am       |   2 +-
>  utils/gssd/gssd_proc.c  |  37 ++++-
>  utils/gssd/krb5_util.c  |   2 +-
>  utils/gssd/krb5_util.h  |   1 +
>  utils/gsskeyd/gsskeyd.c | 371 ++++++++++++++++++++++++++++++++++++++++++++++++
>  6 files changed, 408 insertions(+), 6 deletions(-)
>  create mode 100644 utils/gsskeyd/gsskeyd.c
> 


-- 
Simo Sorce * Red Hat, Inc * New York


  parent reply	other threads:[~2013-10-22 15:02 UTC|newest]

Thread overview: 27+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-10-22 14:22 [PATCH Version 2 0/3] GSSD: Use gss-ctx keys and gsskeyd to sync Kerberos credentials and kernel gss_contexts andros
2013-10-22 14:22 ` [PATCH Version 2 1/3] GSSD add cc_name to upcall andros
2013-10-22 15:07   ` Simo Sorce
2013-10-22 14:22 ` [PATCH Version 2 2/3] WIP: Add gsskeyd andros
2013-10-23 14:30   ` Steve Dickson
2013-10-23 14:40     ` Weston Andros Adamson
2013-10-23 15:02       ` Adamson, Andy
2013-10-22 14:22 ` [PATCH Version 2 3/3] ANDROS: update gsskeyd to use new /run/user/UID/krb5cc/tgt cache file andros
2013-10-22 15:02 ` Simo Sorce [this message]
2013-10-22 15:32   ` [PATCH Version 2 0/3] GSSD: Use gss-ctx keys and gsskeyd to sync Kerberos credentials and kernel gss_contexts Adamson, Andy
2013-10-22 16:09     ` Simo Sorce
2013-10-22 17:00       ` Adamson, Andy
2013-10-22 17:25         ` Simo Sorce
2013-11-20 20:35           ` Adamson, Andy
2013-11-20 20:49             ` Simo Sorce
2013-11-20 21:21               ` Adamson, Andy
2013-11-20 21:24                 ` Adamson, Andy
2013-11-22 19:09                 ` Simo Sorce
2013-11-22 20:44                   ` Adamson, Andy
2013-11-21 13:37               ` Steve Dickson
2013-11-22 19:11                 ` Simo Sorce
2013-11-22 21:28                   ` Trond Myklebust
2013-11-22 21:39                     ` Simo Sorce
2013-10-22 15:46   ` Weston Andros Adamson
2013-10-22 16:11     ` Simo Sorce
2013-10-22 16:14       ` Weston Andros Adamson
2013-10-22 16:39         ` Adamson, Andy

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1382454148.9794.72.camel@willson.li.ssimo.org \
    --to=simo@redhat.com \
    --cc=andros@netapp.com \
    --cc=linux-nfs@vger.kernel.org \
    --cc=steved@redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).