Changeset 421


Ignore:
Timestamp:
Nov 25, 2012, 1:44:37 PM (12 years ago)
Author:
katerina
Message:

Fix for ticket #325 (samhainctl probe command).

Location:
trunk
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/docs/Changelog

    r420 r421  
    113.0.9:
     2        * Fix the probe command (misses clients if their startup message
     3          has been missed)
    24        * Fix the RPM spec file for --enable-network=client and no password
    35          (reported by Mitch St Martin)
  • trunk/src/sh_socket.c

    r383 r421  
    165165#include "sh_utils.h"
    166166
    167 
     167/* The reload list stores information about
     168 * reloads confirmed by clients (startup and/or
     169 * runtime cinfiguration reloaded).
     170 */
    168171struct reload_cmd {
    169172  char          clt[SH_MAXMSGLEN];
     
    235238      if (item->status_now != CLT_INACTIVE)
    236239        {
     240          int flag = 0;
     241
    237242          file = get_client_conf_file (item->hostname, &dummy);
    238243
     
    250255                  if (0 == sl_strcmp(new->clt, item->hostname))
    251256                    {
     257                      flag = 1; /* Client is in list already */
     258
    252259#ifdef SH_DEBUG_SOCKET
    253260                      fprintf(stderr, "%lu <> %lu\n",
     
    266273                  new = new->next;
    267274                }
    268             }
    269         }
    270     }
     275
     276              if (flag == 0)
     277                {
     278                  /* client is active, but start message has been missed; reload
     279                   */
     280                  sl_strlcpy(cmd.cmd, _("RELOAD"),    SH_MAXMSGLEN);
     281                  sl_strlcpy(cmd.clt, item->hostname, SH_MAXMSGLEN);
     282                  sh_socket_add2list (&cmd);
     283
     284                  /* Add the client to the reload list and set
     285                   * time to 0, since we don't know the startup time.
     286                   */
     287                  sh_socket_add2reload (item->hostname);
     288                  new = reloadlist;
     289                  while (new)
     290                    {
     291                      if (0 == sl_strcmp(new->clt, item->hostname))
     292                        {
     293                          new->cti = 0;
     294                          break;
     295                        }
     296                      new = new->next;
     297                    }
     298                }
     299            } /* if stat(file).. */
     300        } /* if !CLT_INACTIVE */
     301    } /* loop over clients */
    271302  return;
    272303}
Note: See TracChangeset for help on using the changeset viewer.