Use `krb5_sock_to_principal'
Send server parameter to krb5_rd_req Set addresses in auth_context git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@2949 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -252,6 +252,7 @@ kerberos5_is(Authenticator *ap, unsigned char *data, int cnt)
|
|||||||
krb5_data outbuf;
|
krb5_data outbuf;
|
||||||
krb5_keyblock *key_block;
|
krb5_keyblock *key_block;
|
||||||
char *name;
|
char *name;
|
||||||
|
krb5_principal server;
|
||||||
|
|
||||||
if (cnt-- < 1)
|
if (cnt-- < 1)
|
||||||
return;
|
return;
|
||||||
@@ -262,8 +263,34 @@ kerberos5_is(Authenticator *ap, unsigned char *data, int cnt)
|
|||||||
|
|
||||||
auth_context = NULL;
|
auth_context = NULL;
|
||||||
|
|
||||||
r = krb5_rd_req(context, &auth_context, &auth,
|
r = krb5_auth_con_init (context, &auth_context);
|
||||||
NULL, NULL, NULL, &ticket);
|
if (r)
|
||||||
|
abort ();
|
||||||
|
|
||||||
|
|
||||||
|
r = krb5_auth_con_setaddrs_from_fd (context,
|
||||||
|
auth_context,
|
||||||
|
0);
|
||||||
|
if (r)
|
||||||
|
abort ();
|
||||||
|
|
||||||
|
r = krb5_sock_to_principal (context,
|
||||||
|
0,
|
||||||
|
"host",
|
||||||
|
KRB5_NT_SRV_HST,
|
||||||
|
&server);
|
||||||
|
if (r)
|
||||||
|
abort ();
|
||||||
|
|
||||||
|
|
||||||
|
r = krb5_rd_req(context,
|
||||||
|
&auth_context,
|
||||||
|
&auth,
|
||||||
|
server,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
&ticket);
|
||||||
|
krb5_free_principal (context, server);
|
||||||
|
|
||||||
if (r) {
|
if (r) {
|
||||||
char *errbuf;
|
char *errbuf;
|
||||||
|
Reference in New Issue
Block a user