/* * $Source$ * $Author$ * $Header$ * * Copyright (C) 1987 by the Massachusetts Institute of Technology * For copying and distribution information, please see the file * . * * Handles the client side of the sending of authenticators to * the sms server. */ #ifndef lint static char *rcsid_sms_auth_c = "$Header$"; #endif lint #include #include "sms_private.h" #include #include #include /* Authenticate this client with the SMS server. prog is the name of the * client program, and will be recorded in the database. */ int sms_auth(prog) char *prog; { register int status; sms_params params_st; char *args[2]; int argl[2]; char realm[REALM_SZ], host[BUFSIZ], *p; register sms_params *params = ¶ms_st; sms_params *reply = NULL; KTEXT_ST auth; CHECK_CONNECTED; /* Build a Kerberos authenticator. */ bzero(host, sizeof(host)); if (status = sms_host(host, sizeof(host) - 1)) return status; strcpy(realm, krb_realmofhost(host)); for (p = host; *p && *p != '.'; p++) if (isupper(*p)) *p = tolower(*p); *p = 0; status = krb_mk_req(&auth, MOIRA_SNAME, host, realm, 0); if (status != KSUCCESS) { status += ERROR_TABLE_BASE_krb; return status; } params->sms_version_no = sending_version_no; params->sms_procno = SMS_AUTH; params->sms_argc = 2; params->sms_argv = args; params->sms_argl = argl; params->sms_argv[0] = (char *)auth.dat; params->sms_argl[0] = auth.length; params->sms_argv[1] = prog; params->sms_argl[1] = strlen(prog) + 1; if (sending_version_no == SMS_VERSION_1) params->sms_argc = 1; if ((status = sms_do_call(params, &reply)) == 0) status = reply->sms_status; sms_destroy_reply(reply); return status; }