6 * Copyright (C) 1987 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 "sms_private.h"
22 extern int krb_err_base;
24 /* Authenticate this client with the SMS server. prog is the name of the
25 * client program, and will be recorded in the database.
37 register sms_params *params = ¶ms_st;
38 sms_params *reply = NULL;
44 * Build a Kerberos authenticator.
45 * The "service" and "instance" should not be hardcoded here.
48 if ((status = get_krbrlm(realm, 1)) != KSUCCESS) {
51 status = krb_mk_req(&auth, "sms", "sms", realm, 0);
52 if (status != KSUCCESS) {
53 status += krb_err_base;
56 params->sms_version_no = sending_version_no;
57 params->sms_procno = SMS_AUTH;
59 params->sms_argv = args;
60 params->sms_argl = argl;
61 params->sms_argv[0] = (char *)auth.dat;
62 params->sms_argl[0] = auth.length;
63 params->sms_argv[1] = prog;
64 params->sms_argl[1] = strlen(prog) + 1;
66 if (sending_version_no == SMS_VERSION_1)
69 if ((status = sms_do_call(params, &reply)) == 0)
70 status = reply->sms_status;
72 sms_destroy_reply(reply);
81 * c-continued-statement-offset: 4