Description |
|
This routine formats a KRB_SAFE message into outbuf.
The userdata argument is formatted
as the user data in the message. Portions of auth_context specify
the checksum type, the keyblock that might be used to seed the checksum,
and full addresses (host and port) for the sender and receiver.
The local_addr portion of *auth_context is
used to form the addresses used in the KRB_SAFE message. The remote_addr is
optional; if the receiver's address is not known, it may be replaced by
NULL. The local_addr argument, however,
is mandatory.
If timestamps are to be used (that is, if KRB5_AUTH_CONTEXT_DO_TIME
is set), an entry describing the message will be entered in the
replay cache so that the caller may detect if this message is sent
back by an attacker. If KRB5_AUTH_CONTEXT_DO_TIME is not set, the auth_context replay
cache is not used.
If sequence numbers are to be used (if either KRB5_AUTH_CONTEXT_DO_SEQUENCE
or KRB5_AUTH_CONTEXT_RET_SEQUENCE is set), then auth_context local
sequence number will be placed in the protected message as its sequence
number.
The outbuf buffer storage (outbuf->data)
is allocated, and should be freed by the caller when finished.