Subject: | MEMORY keytab |
This is a first cut at the memory keytab.
Outstanding issue:
There is no krb5_kt_destroy() function. This means that there is no
mechanism by which a keytab can be destroyed once it is created.
Heimdal destroys the MEMORY keytab whenever the krb5_kt_close results in
a zero reference count being reached. However, this seems wrong to me.
If you were to apply this semantic to FILE keytabs it would be the
equivalent of deleting the keytab file whenever there are no users of
the keytab. This semantic appears to be wrong to me.
I believe that there should be a new function:
krb5_error_code KRB5_CALLCONV
krb5_kt_destroy(krb5_context context, krb5_keytab keytab);
The semantics of this function are that the contents of the keytab are
destroyed. For the FILE ccache, this would mean truncate the contents
of the file and then unlink. For the MEMORY ccache, this would mean
empty the keytab of all entries and if it has a refcount of 0 remove the
keytab from the in-memory list.
Please comment.
A revised patch will be added to the ticket tomorrow after further testing.
Outstanding issue:
There is no krb5_kt_destroy() function. This means that there is no
mechanism by which a keytab can be destroyed once it is created.
Heimdal destroys the MEMORY keytab whenever the krb5_kt_close results in
a zero reference count being reached. However, this seems wrong to me.
If you were to apply this semantic to FILE keytabs it would be the
equivalent of deleting the keytab file whenever there are no users of
the keytab. This semantic appears to be wrong to me.
I believe that there should be a new function:
krb5_error_code KRB5_CALLCONV
krb5_kt_destroy(krb5_context context, krb5_keytab keytab);
The semantics of this function are that the contents of the keytab are
destroyed. For the FILE ccache, this would mean truncate the contents
of the file and then unlink. For the MEMORY ccache, this would mean
empty the keytab of all entries and if it has a refcount of 0 remove the
keytab from the in-memory list.
Please comment.
A revised patch will be added to the ticket tomorrow after further testing.
Message body not shown because it is not plain text.