6 * Copyright (C) 1987, 1990 by the Massachusetts Institute of Technology
7 * For copying and distribution information, please see the file
10 * Handles the client side of the sending of authenticators to
15 static char *rcsid_sms_auth_c = "$Header$";
18 #include <mit-copyright.h>
19 #include "mr_private.h"
25 /* Authenticate this client with the MR server. prog is the name of the
26 * client program, and will be recorded in the database.
36 char realm[REALM_SZ], host[BUFSIZ], *p;
38 register mr_params *params = ¶ms_st;
39 mr_params *reply = NULL;
44 /* Build a Kerberos authenticator. */
46 bzero(host, sizeof(host));
47 if (status = mr_host(host, sizeof(host) - 1))
50 strcpy(realm, krb_realmofhost(host));
51 for (p = host; *p && *p != '.'; p++)
56 status = krb_mk_req(&auth, MOIRA_SNAME, host, realm, 0);
57 if (status != KSUCCESS) {
58 status += ERROR_TABLE_BASE_krb;
61 params->mr_version_no = sending_version_no;
62 params->mr_procno = MR_AUTH;
64 params->mr_argv = args;
65 params->mr_argl = argl;
66 params->mr_argv[0] = (char *)auth.dat;
67 params->mr_argl[0] = auth.length;
68 params->mr_argv[1] = prog;
69 params->mr_argl[1] = strlen(prog) + 1;
71 if (sending_version_no == MR_VERSION_1)
74 if ((status = mr_do_call(params, &reply)) == 0)
75 status = reply->mr_status;
77 mr_destroy_reply(reply);