]> andersk Git - moira.git/blobdiff - update/client.c
Code style cleanup. (No functional changes)
[moira.git] / update / client.c
index a8b85856d7882c29980c1b270229784dc9b9c77a..30aaa1aefb1403b9e3173937d14852544d24a42c 100644 (file)
@@ -26,20 +26,20 @@ static char *rcsid_client2_c = "$Header$";
 
 #include <mit-copyright.h>
 #include <stdio.h>
-#include <strings.h>
+#include <stdlib.h>
+#include <string.h>
 #include <gdb.h>
 #include <sys/param.h>
 #include <sys/wait.h>
 #include <sys/socket.h>
 #include <update.h>
 #include <errno.h>
-#include <dcm.h>
 #include <moira.h>
 #include <moira_site.h>
 #include <krb.h>
 
-extern char *malloc();
 extern int errno, dbg;
+extern C_Block session;
 
 static char buf[BUFSIZ];
 static int code;
@@ -62,211 +62,112 @@ CONNECTION conn;
  * PROBLEMS:
  *
  */
-static void
-initialize()
+static void initialize()
 {
-    static int initialized = 0;
+  static int initialized = 0;
 
-    if (!initialized) {
-       gdb_init();
-       initialized++;
+  if (!initialized)
+    {
+      gdb_init();
+      initialized++;
     }
 }
 
-
-/*
- * FUNCTION:
- *     mr_update_server(service, machine, target_path)
- * DESCRIPTION:
- *     Attempts to perform an update to the named machine
- *     of the named service.  The file DCM_DIR/service.out
- *     will be sent, then the file SMS_DIR/bin/service.sh,
- *     the the shell script will be executed.
- * INPUT:
- *     service
- *             Name of service to be updated; used to find
- *             the source data file in the MR data directory.
- *     machine
- *     target_path
- *             Location to install the file.
- * RETURN VALUE:
- *     int:
- *             Error code, or zero if no error was detected
- *             in the data supplied to this routine.
- * SIDE EFFECTS:
- *     May write information to logs.
- * PROBLEMS:
- *
- */
-
-int
-mr_update_server(service, machine, target_path, instructions)
-char *service;
-char *machine;
-char *target_path;
-char *instructions;
+int send_auth(char *host_name)
 {
-#define ASSERT(condition,stat,amsg) \
-    if (!(condition)) { com_err(whoami, stat, amsg); return(stat); }
-#define ASSERT2(condition,stat,amsg,arg1) \
-    if (!(condition)) { com_err(whoami, stat, amsg, arg1); return(stat); }
-#define NONNULL(str) \
-    (((str) != (char *)NULL) && (strlen(str) != 0))
-
-    char *service_address, *service_updated, *pathname;
-    int on;
-    
-    /* some sanity checking of arguments while we build data */
-    ASSERT(NONNULL(machine), MR_INTERNAL, " null host name");
-    ASSERT(NONNULL(service), MR_INTERNAL, " null service name");
-    ASSERT((strlen(machine) + strlen(service) + 2 < BUFSIZ), MR_ARG_TOO_LONG,
-          " machine and service names");
-    sprintf(buf, "%s:%s", machine, service);
-    service_updated = strsave(buf);
-    ASSERT(NONNULL(service_updated), MR_NO_MEM, " for service name");
-    ASSERT((strlen(machine)+strlen(SERVICE_NAME)+2 < BUFSIZ), MR_ARG_TOO_LONG,
-          " machine and update service name");
-    sprintf(buf, "%s:%s", machine, SERVICE_NAME);
-    service_address = strsave(buf);
-    ASSERT(NONNULL(service_address), MR_NO_MEM, " for service address");
-    ASSERT(NONNULL(target_path), MR_INTERNAL, " null target pathname");
-    ASSERT((strlen(target_path) < MAXPATHLEN), MR_ARG_TOO_LONG,
-          " target pathname");
-    ASSERT2(target_path[0] == '/', MR_NOT_UNIQUE,
-          " non-absolute pathname supplied \"%s\"", target_path);
-    sprintf(buf, "%s/%s.out", DCM_DIR, service);
-    pathname = strsave(buf);
-    ASSERT(NONNULL(pathname), MR_NO_MEM, " for pathname");
-    ASSERT(NONNULL(instructions), MR_NO_MEM, " for instructions");
-    ASSERT((strlen(instructions) < MAXPATHLEN), MR_ARG_TOO_LONG,
-          " instruction pathname");
-    
-    initialize();
-    com_err(whoami, 0, "starting update for %s", service_updated);
-    
-    /* open connection */
-    conn = start_server_connection(service_address, "");
-    if (!conn || (connection_status(conn) == CON_STOPPED)) {
-       com_err(whoami, connection_errno(conn),
-               " can't connect to update %s", service_address);
-       return(MR_CANT_CONNECT);
+  KTEXT_ST ticket_st;
+  KTEXT ticket = &ticket_st;
+  STRING data;
+  register int code;
+  int response;
+  int auth_version = 2;
+
+  code = get_mr_update_ticket(host_name, ticket);
+  if (code)
+    return code;
+  STRING_DATA(data) = "AUTH_002";
+  MAX_STRING_SIZE(data) = 9;
+  code = send_object(conn, (char *)&data, STRING_T);
+  if (code)
+    return connection_errno(conn);
+  code = receive_object(conn, (char *)&response, INTEGER_T);
+  if (code)
+    return connection_errno(conn);
+  if (response)
+    {
+      STRING_DATA(data) = "AUTH_001";
+      MAX_STRING_SIZE(data) = 9;
+      code = send_object(conn, (char *)&data, STRING_T);
+      if (code)
+       return connection_errno(conn);
+      code = receive_object(conn, (char *)&response, INTEGER_T);
+      if (code)
+       return connection_errno(conn);
+      if (response)
+       return response;
+      auth_version = 1;
     }
-    on = 1;
-    setsockopt(conn->in.fd, SOL_SOCKET, SO_KEEPALIVE, &on, sizeof(on));
-    
-    /* send authenticators */
-    code = send_auth(machine);
-    if (code) {
-       com_err(whoami, code, " authorization attempt to %s failed",
-               service_updated);
-       goto update_failed;
+  STRING_DATA(data) = (char *)ticket->dat;
+  MAX_STRING_SIZE(data) = ticket->length;
+  code = send_object(conn, (char *)&data, STRING_T);
+  if (code)
+    return connection_errno(conn);
+  code = receive_object(conn, (char *)&response, INTEGER_T);
+  if (code)
+    return connection_errno(conn);
+  if (response)
+    return response;
+
+  if (auth_version == 2)
+    {
+      des_key_schedule sched;
+      C_Block enonce;
+
+      code = receive_object(conn, (char *)&data, STRING_T);
+      if (code)
+       return connection_errno(conn);
+      des_key_sched(session, sched);
+      des_ecb_encrypt(STRING_DATA(data), enonce, sched, 1);
+      STRING_DATA(data) = enonce;
+      code = send_object(conn, (char *)&data, STRING_T);
+      if (code)
+       return connection_errno(conn);
+      code = receive_object(conn, (char *)&response, INTEGER_T);
+      if (code)
+       return connection_errno(conn);
+      if (response)
+       return response;
     }
-    
-    code = send_file(pathname, target_path);
-    if (code)
-      goto update_failed;
-
-    /* send instructions for installation */
-    strcpy(buf, "/tmp/moira-update.XXXXXX");
-    mktemp(buf);
-    code = send_file(instructions, buf);
-    if (code)
-      goto update_failed;
 
-    /* perform installation */
-    code = execute(buf);
-    if (code) {
-       com_err(whoami, code, " installation of %s failed, code = %d",
-               service_updated, code);
-       goto update_failed;
-    }
-    
-    /* finished updates */
-    code = MR_SUCCESS;
-
- update_failed:
-    send_quit();
-    conn = sever_connection(conn);
-    return(code);
-
-#undef NONNULL
-#undef ASSERT
-}
-
-
-static
-send_auth(host_name)
-char *host_name;
-{
-    KTEXT_ST ticket_st;
-    KTEXT ticket = &ticket_st;
-    STRING data;
-    register int code;
-    int response;
-    
-    code = get_mr_update_ticket(host_name, ticket);
-    if (code) {
-       return(code);
-    }
-    STRING_DATA(data) = "AUTH_001";
-    MAX_STRING_SIZE(data) = 9;
-    code = send_object(conn, (char *)&data, STRING_T);
-    if (code) {
-       return(connection_errno(conn));
-    }
-    code = receive_object(conn, (char *)&response, INTEGER_T);
-    if (code) {
-       return(connection_errno(conn));
-    }
-    if (response) {
-       return(response);
-    }
-    STRING_DATA(data) = (char *)ticket->dat;
-    MAX_STRING_SIZE(data) = ticket->length;
-    code = send_object(conn, (char *)&data, STRING_T);
-    if (code) {
-       return(connection_errno(conn));
-    }
-    code = receive_object(conn, (char *)&response, INTEGER_T);
-    if (code) {
-       return(connection_errno(conn));
-    }
-    if (response) {
-       return(response);
-    }
-    return(MR_SUCCESS);
+  return MR_SUCCESS;
 }
 
-static
-execute(path)
-    char *path;
+int execute(char *path)
 {
-    int response;
-    STRING data;
-    register int code;
-    
-    string_alloc(&data, BUFSIZ);
-    sprintf(STRING_DATA(data), "EXEC_002 %s", path);
-    code = send_object(conn, (char *)&data, STRING_T);
-    if (code)
-       return(connection_errno(conn));
-    code = receive_object(conn, (char *)&response, INTEGER_T);
-    if (code)
-       return(connection_errno(conn));
-    if (dbg & DBG_TRACE)
-      com_err(whoami, response, "execute returned %d", response);
-    if (response)
-      return(response);
-    return(MR_SUCCESS);
+  int response;
+  STRING data;
+  register int code;
+
+  string_alloc(&data, BUFSIZ);
+  sprintf(STRING_DATA(data), "EXEC_002 %s", path);
+  code = send_object(conn, (char *)&data, STRING_T);
+  if (code)
+    return connection_errno(conn);
+  code = receive_object(conn, (char *)&response, INTEGER_T);
+  if (code)
+    return connection_errno(conn);
+  if (response)
+    return response;
+  return MR_SUCCESS;
 }
 
-send_quit()
+send_quit(void)
 {
-    STRING str;
-    if (!conn)
-       return;
-    string_alloc(&str, 5);
-    (void) strcpy(STRING_DATA(str), "quit");
-    (void) send_object(conn, (char *)&str, STRING_T);
-    string_free(&str);
+  STRING str;
+  if (!conn)
+    return;
+  string_alloc(&str, 5);
+  strcpy(STRING_DATA(str), "quit");
+  send_object(conn, (char *)&str, STRING_T);
+  string_free(&str);
 }
This page took 0.063425 seconds and 4 git commands to generate.