and some more improvements
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@8317 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 1998 Kungliga Tekniska H<>gskolan
|
* Copyright (c) 1997 - 2000 Kungliga Tekniska H<>gskolan
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
* (Royal Institute of Technology, Stockholm, Sweden).
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
@@ -47,7 +47,8 @@ connect_to_master (krb5_context context, const char *master)
|
|||||||
krb5_err (context, 1, errno, "socket AF_INET");
|
krb5_err (context, 1, errno, "socket AF_INET");
|
||||||
memset (&addr, 0, sizeof(addr));
|
memset (&addr, 0, sizeof(addr));
|
||||||
addr.sin_family = AF_INET;
|
addr.sin_family = AF_INET;
|
||||||
addr.sin_port = htons(4711);
|
addr.sin_port = krb5_getportbyname (context,
|
||||||
|
IPROP_SERVICE, "tcp", IPROP_PORT);
|
||||||
he = roken_gethostbyname (master);
|
he = roken_gethostbyname (master);
|
||||||
if (he == NULL)
|
if (he == NULL)
|
||||||
krb5_errx (context, 1, "gethostbyname: %s", hstrerror(h_errno));
|
krb5_errx (context, 1, "gethostbyname: %s", hstrerror(h_errno));
|
||||||
@@ -58,7 +59,8 @@ connect_to_master (krb5_context context, const char *master)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
get_creds(krb5_context context, krb5_ccache *cache, const char *host)
|
get_creds(krb5_context context, const char *keytab_str,
|
||||||
|
krb5_ccache *cache, const char *host)
|
||||||
{
|
{
|
||||||
krb5_keytab keytab;
|
krb5_keytab keytab;
|
||||||
krb5_principal client;
|
krb5_principal client;
|
||||||
@@ -71,9 +73,14 @@ get_creds(krb5_context context, krb5_ccache *cache, const char *host)
|
|||||||
char my_hostname[128];
|
char my_hostname[128];
|
||||||
char *server;
|
char *server;
|
||||||
|
|
||||||
ret = krb5_kt_default(context, &keytab);
|
ret = krb5_kt_register(context, &hdb_kt_ops);
|
||||||
if(ret) krb5_err(context, 1, ret, "krb5_kt_default");
|
if(ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_kt_register");
|
||||||
|
|
||||||
|
ret = krb5_kt_resolve(context, keytab_str, &keytab);
|
||||||
|
if(ret)
|
||||||
|
krb5_err(context, 1, ret, "%s", keytab_str);
|
||||||
|
|
||||||
gethostname (my_hostname, sizeof(my_hostname));
|
gethostname (my_hostname, sizeof(my_hostname));
|
||||||
ret = krb5_sname_to_principal (context, my_hostname, IPROP_NAME,
|
ret = krb5_sname_to_principal (context, my_hostname, IPROP_NAME,
|
||||||
KRB5_NT_SRV_HST, &client);
|
KRB5_NT_SRV_HST, &client);
|
||||||
@@ -166,7 +173,7 @@ receive (krb5_context context,
|
|||||||
left = sp->seek (sp, -16, SEEK_CUR);
|
left = sp->seek (sp, -16, SEEK_CUR);
|
||||||
right = sp->seek (sp, 0, SEEK_END);
|
right = sp->seek (sp, 0, SEEK_END);
|
||||||
buf = malloc (right - left);
|
buf = malloc (right - left);
|
||||||
if (buf == NULL) {
|
if (buf == NULL && (right - left) != 0) {
|
||||||
krb5_warnx (context, "malloc: no memory");
|
krb5_warnx (context, "malloc: no memory");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -203,15 +210,91 @@ receive (krb5_context context,
|
|||||||
krb5_err (context, 1, ret, "db->close");
|
krb5_err (context, 1, ret, "db->close");
|
||||||
}
|
}
|
||||||
|
|
||||||
char *realm;
|
static void
|
||||||
int version_flag;
|
receive_everything (krb5_context context, int *fd,
|
||||||
int help_flag;
|
kadm5_server_context *server_context)
|
||||||
struct getargs args[] = {
|
{
|
||||||
|
int ret;
|
||||||
|
krb5_data data;
|
||||||
|
int32_t vno;
|
||||||
|
int32_t opcode;
|
||||||
|
|
||||||
|
ret = server_context->db->open(context,
|
||||||
|
server_context->db,
|
||||||
|
O_RDWR | O_CREAT | O_TRUNC, 0);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "db->open");
|
||||||
|
|
||||||
|
do {
|
||||||
|
krb5_data data;
|
||||||
|
krb5_storage *sp;
|
||||||
|
|
||||||
|
ret = krb5_read_message (context, fd, &data);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "krb5_read_message");
|
||||||
|
|
||||||
|
sp = krb5_storage_from_data (&data);
|
||||||
|
krb5_ret_int32 (sp, &opcode);
|
||||||
|
if (opcode == ONE_PRINC) {
|
||||||
|
krb5_data fake_data;
|
||||||
|
hdb_entry entry;
|
||||||
|
|
||||||
|
fake_data.data = (char *)data.data + 4;
|
||||||
|
fake_data.length = data.length - 4;
|
||||||
|
|
||||||
|
ret = hdb_value2entry (context, &fake_data, &entry);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "hdb_value2entry");
|
||||||
|
hdb_free_entry (context, &entry);
|
||||||
|
krb5_data_free (&data);
|
||||||
|
}
|
||||||
|
} while (opcode == ONE_PRINC);
|
||||||
|
|
||||||
|
if (opcode != NOW_YOU_HAVE)
|
||||||
|
krb5_errx (context, 1, "receive_everything: strange %d", opcode);
|
||||||
|
|
||||||
|
_krb5_get_int ((char *)data.data + 4, &vno, 4);
|
||||||
|
|
||||||
|
ret = kadm5_log_reinit (server_context);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "kadm5_log_reinit");
|
||||||
|
|
||||||
|
ret = kadm5_log_set_version (server_context, vno - 1);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "kadm5_log_set_version");
|
||||||
|
|
||||||
|
ret = kadm5_log_nop (server_context);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "kadm5_log_nop");
|
||||||
|
|
||||||
|
krb5_data_free (&data);
|
||||||
|
|
||||||
|
ret = server_context->db->close (context, server_context->db);
|
||||||
|
if (ret)
|
||||||
|
krb5_err (context, 1, ret, "db->close");
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *realm;
|
||||||
|
static int version_flag;
|
||||||
|
static int help_flag;
|
||||||
|
static char *keytab_str = "HDB:";
|
||||||
|
|
||||||
|
static struct getargs args[] = {
|
||||||
{ "realm", 'r', arg_string, &realm },
|
{ "realm", 'r', arg_string, &realm },
|
||||||
|
{ "keytab", 'k', arg_string, &keytab_str,
|
||||||
|
"keytab to get authentication from", "kspec" },
|
||||||
{ "version", 0, arg_flag, &version_flag },
|
{ "version", 0, arg_flag, &version_flag },
|
||||||
{ "help", 0, arg_flag, &help_flag }
|
{ "help", 0, arg_flag, &help_flag }
|
||||||
};
|
};
|
||||||
int num_args = sizeof(args) / sizeof(args[0]);
|
|
||||||
|
static int num_args = sizeof(args) / sizeof(args[0]);
|
||||||
|
|
||||||
|
static void
|
||||||
|
usage (int code, struct getargs *args, int num_args)
|
||||||
|
{
|
||||||
|
arg_printusage (args, num_args, NULL, "master");
|
||||||
|
exit (code);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
@@ -225,18 +308,31 @@ main(int argc, char **argv)
|
|||||||
int master_fd;
|
int master_fd;
|
||||||
krb5_ccache ccache;
|
krb5_ccache ccache;
|
||||||
krb5_principal server;
|
krb5_principal server;
|
||||||
|
|
||||||
int optind;
|
int optind;
|
||||||
|
const char *master;
|
||||||
|
|
||||||
optind = krb5_program_setup(&context, argc, argv, args, num_args, NULL);
|
optind = krb5_program_setup(&context, argc, argv, args, num_args,
|
||||||
|
usage);
|
||||||
|
|
||||||
if(help_flag)
|
if(help_flag)
|
||||||
krb5_std_usage(0, args, num_args);
|
usage (0, args, num_args);
|
||||||
if(version_flag) {
|
if(version_flag) {
|
||||||
print_version(NULL);
|
print_version(NULL);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
argc -= optind;
|
||||||
|
argv += optind;
|
||||||
|
|
||||||
|
if (argc != 1)
|
||||||
|
usage (1, args, num_args);
|
||||||
|
|
||||||
|
master = argv[0];
|
||||||
|
|
||||||
|
ret = krb5_kt_register(context, &hdb_kt_ops);
|
||||||
|
if(ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_kt_register");
|
||||||
|
|
||||||
memset(&conf, 0, sizeof(conf));
|
memset(&conf, 0, sizeof(conf));
|
||||||
if(realm) {
|
if(realm) {
|
||||||
conf.mask |= KADM5_CONFIG_REALM;
|
conf.mask |= KADM5_CONFIG_REALM;
|
||||||
@@ -257,11 +353,11 @@ main(int argc, char **argv)
|
|||||||
if (ret)
|
if (ret)
|
||||||
krb5_err (context, 1, ret, "kadm5_log_init");
|
krb5_err (context, 1, ret, "kadm5_log_init");
|
||||||
|
|
||||||
get_creds(context, &ccache, argv[1]);
|
get_creds(context, keytab_str, &ccache, master);
|
||||||
|
|
||||||
master_fd = connect_to_master (context, argv[1]);
|
master_fd = connect_to_master (context, master);
|
||||||
|
|
||||||
ret = krb5_sname_to_principal (context, argv[1], IPROP_NAME,
|
ret = krb5_sname_to_principal (context, master, IPROP_NAME,
|
||||||
KRB5_NT_SRV_HST, &server);
|
KRB5_NT_SRV_HST, &server);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_err (context, 1, ret, "krb5_sname_to_principal");
|
krb5_err (context, 1, ret, "krb5_sname_to_principal");
|
||||||
@@ -287,7 +383,7 @@ main(int argc, char **argv)
|
|||||||
if (ret)
|
if (ret)
|
||||||
krb5_err (context, 1, ret, "krb5_read_message");
|
krb5_err (context, 1, ret, "krb5_read_message");
|
||||||
|
|
||||||
ret = krb5_rd_priv (context, auth_context, &data, &out, NULL);
|
ret = krb5_rd_priv (context, auth_context, &data, &out, NULL);
|
||||||
krb5_data_free (&data);
|
krb5_data_free (&data);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_err (context, 1, ret, "krb5_rd_priv");
|
krb5_err (context, 1, ret, "krb5_rd_priv");
|
||||||
@@ -300,7 +396,12 @@ main(int argc, char **argv)
|
|||||||
ihave (context, auth_context, master_fd,
|
ihave (context, auth_context, master_fd,
|
||||||
server_context->log_context.version);
|
server_context->log_context.version);
|
||||||
break;
|
break;
|
||||||
|
case TELL_YOU_EVERYTHING :
|
||||||
|
receive_everything (context, &master_fd, server_context);
|
||||||
|
break;
|
||||||
|
case NOW_YOU_HAVE :
|
||||||
case I_HAVE :
|
case I_HAVE :
|
||||||
|
case ONE_PRINC :
|
||||||
default :
|
default :
|
||||||
krb5_warnx (context, "Ignoring command %d", tmp);
|
krb5_warnx (context, "Ignoring command %d", tmp);
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user