]> andersk Git - moira.git/blobdiff - lib/mr_auth.c
Added support for DEBUG_LIBS so that when this is defined
[moira.git] / lib / mr_auth.c
index 852bf251508efd5df3d51803da489368e1b122e7..dee6fae7a17bb6610f99848383375690e3c47b4f 100644 (file)
@@ -4,17 +4,8 @@
  *     $Header$
  *
  *     Copyright (C) 1987 by the Massachusetts Institute of Technology
- *
- *     $Log$
- *     Revision 1.3  1987-06-16 17:47:20  wesommer
- *     Clean up memory allocation, indenting.
- *
- * Revision 1.2  87/05/31  22:03:23  wesommer
- * It's working better.
- * 
- * Revision 1.1  87/05/20  03:11:18  wesommer
- * Initial revision
- * 
+ *     For copying and distribution information, please see the file
+ *     <mit-copyright.h>.
  *
  *     Handles the client side of the sending of authenticators to
  * the sms server.     
 static char *rcsid_sms_auth_c = "$Header$";
 #endif lint
 
+#include <mit-copyright.h>
 #include "sms_private.h"
 #include <krb.h>
+#include "krb_et.h"
+
 
-extern int krb_err_base;
+/* 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()
+int sms_auth(prog)
+char *prog;
 {
     register int status;
     sms_params params_st;
-    char *args[1];
-    int argl[1];
-    
+    char *args[2];
+    int argl[2];
+    char realm[REALM_SZ];
+
     register sms_params *params = &params_st;
     sms_params *reply = NULL;
     KTEXT_ST auth;
@@ -47,18 +45,27 @@ int sms_auth()
      * The "service" and "instance" should not be hardcoded here.
      */
        
-    status = mk_ap_req(&auth, "sms", "sms", "ATHENA.MIT.EDU", 0);
-    if (status != KSUCCESS) {
-       status += krb_err_base;
+    if ((status = get_krbrlm(realm, 1)) != KSUCCESS) {
        return status;
     }
+    status = krb_mk_req(&auth, "sms", "sms", 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 = 1;
+    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;
 
@@ -66,14 +73,3 @@ int sms_auth()
 
     return status;
 }
-
-/*
- * Local Variables:
- * mode: c
- * c-indent-level: 4
- * c-continued-statement-offset: 4
- * c-brace-offset: -4
- * c-argdecl-indent: 4
- * c-label-offset: -4
- * End:
- */
This page took 0.033966 seconds and 4 git commands to generate.