Proposal to export gssapi context
Sam Hartman
hartmans at MIT.EDU
Wed Mar 24 14:49:38 EST 2004
>>>>> "kwc" == Kevin Coffman <kwc at citi.umich.edu> writes:
kwc> Brought to krbdev...
kwc> The kernel implementation of rpcsec_gss used for NFSv4 requires context
kwc> information be negotiated in user-land and then passed down for use in the
kwc> kernel. gss_export_context() exports the context as an opaque object which
kwc> cannot be used for this purpose. We are proposing three new APIs. One is
kwc> to restrict the encryption types negotiated in user-land to the set that the
kwc> kernel can use. The other two are to export context information into a
kwc> usable structure, and then free that structure.
kwc> Comments, suggestions, welcome.
#define GSS_C_LUCID_CONTEXT_CURRENT_VERSION GSS_C_LUCID_CONTEXT_VERSION_1
I don't think having a macro for the current version in a public
header is a good idea. People might use it and failing to think of a
way of using it that would be correct.
typedef struct gss_krb5_lucid_context {
The version number should be in the structure name.
It seems like you actually only need two keys: the context key and the
server subkey. You can determine the sequence key from the context
key. As Ken pointed out you don't need both enctypes and keys; the
key contains the enctype.
Presumably the return from krb5_gss_export_lucid_context should be a
void * and cast by the caller after looking at the version numbers.
--Sam
More information about the krbdev
mailing list