Add more fields.
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@2343 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -3,11 +3,14 @@
|
||||
RCSID("$Id$");
|
||||
|
||||
krb5_error_code
|
||||
krb5_mk_error(krb5_principal princ,
|
||||
krb5_mk_error(krb5_context context,
|
||||
krb5_error_code error_code,
|
||||
char *e_text,
|
||||
krb5_data *e_data,
|
||||
krb5_data *err)
|
||||
const char *e_text,
|
||||
const krb5_data *e_data,
|
||||
const krb5_principal client,
|
||||
const krb5_principal server,
|
||||
time_t ctime,
|
||||
krb5_data *reply)
|
||||
{
|
||||
KRB_ERROR msg;
|
||||
unsigned char buf[1024];
|
||||
@@ -16,20 +19,27 @@ krb5_mk_error(krb5_principal princ,
|
||||
msg.pvno = 5;
|
||||
msg.msg_type = krb_error;
|
||||
msg.stime = time(0);
|
||||
if(ctime){
|
||||
msg.ctime = &ctime;
|
||||
}
|
||||
msg.error_code = error_code;
|
||||
#ifdef USE_ASN1_PRINCIPAL
|
||||
msg.realm = princ->realm;
|
||||
#else
|
||||
msg.realm = princ->realm.data;
|
||||
#endif
|
||||
krb5_principal2principalname(&msg.sname, princ);
|
||||
if (e_text)
|
||||
msg.e_text = &e_text;
|
||||
msg.e_text = (general_string*)&e_text;
|
||||
if (e_data)
|
||||
msg.e_data = e_data;
|
||||
encode_KRB_ERROR(buf + sizeof(buf) - 1, sizeof(buf), &msg, &err->length);
|
||||
err->data = malloc(err->length);
|
||||
memcpy(err->data, buf + sizeof(buf) - err->length, err->length);
|
||||
msg.e_data = (octet_string*)e_data;
|
||||
#ifdef USE_ASN1_PRINCIPAL
|
||||
msg.realm = server->realm;
|
||||
#else
|
||||
msg.realm = server->realm.data;
|
||||
#endif
|
||||
msg.sname = server->name;
|
||||
if(client){
|
||||
msg.crealm = &client->realm;
|
||||
msg.cname = &client->name;
|
||||
}
|
||||
encode_KRB_ERROR(buf + sizeof(buf) - 1, sizeof(buf), &msg, &reply->length);
|
||||
reply->data = malloc(reply->length);
|
||||
memcpy(reply->data, buf + sizeof(buf) - reply->length, reply->length);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user