Diff for /freem/src/fmadm.c between versions 1.26 and 1.29

version 1.26, 2025/04/02 14:37:57 version 1.29, 2025/04/03 01:41:02
Line 24 Line 24
  *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.   *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.
  *   *
  *   $Log$   *   $Log$
    *   Revision 1.29  2025/04/03 01:41:02  snw
    *   New features frozen; prepare 0.63.0-rc1
    *
    *   Revision 1.28  2025/04/02 19:59:38  snw
    *   Automatically modify env.conf from fmadm reconfigure
    *
    *   Revision 1.27  2025/04/02 15:36:25  snw
    *   Do extensive result checking for environment stop/start/restart in fmadm
    *
  *   Revision 1.26  2025/04/02 14:37:57  snw   *   Revision 1.26  2025/04/02 14:37:57  snw
  *   Improve environment control parts of fmadm   *   Improve environment control parts of fmadm
  *   *
Line 168  extern char config_file[4096]; Line 177  extern char config_file[4096];
 extern char env_config_file[4096];  extern char env_config_file[4096];
 extern char env_user[255];  extern char env_user[255];
 extern char env_group[255];  extern char env_group[255];
   extern char env_enabled[10];
   
 int fm_shell(void);  int fm_shell(void);
 void fm_checkperms(void);  void fm_checkperms(void);
Line 177  int fm_daemonctl (short action, short ob Line 187  int fm_daemonctl (short action, short ob
 void fm_write (FILE *file, char *buf);  void fm_write (FILE *file, char *buf);
 int fma_jobs_remove (int optc, char **opts);  int fma_jobs_remove (int optc, char **opts);
 void set_permissions(char *path, char *user, char *grp, int mode);  void set_permissions(char *path, char *user, char *grp, int mode);
   int fm_environment_running (char *env);
 extern int read_profile_string(char *file, char *section, char *key, char *value);  extern int read_profile_string(char *file, char *section, char *key, char *value);
   
 int main (int argc, char **argv)  int main (int argc, char **argv)
Line 197  int main (int argc, char **argv) Line 208  int main (int argc, char **argv)
     short got_action = FALSE;      short got_action = FALSE;
     short got_object = FALSE;      short got_object = FALSE;
   
       strcpy (env_enabled, "true");
   
     /* snprintf (config_file, 4096, "%s/freem.conf", SYSCONFDIR); */      /* snprintf (config_file, 4096, "%s/freem.conf", SYSCONFDIR); */
   
Line 283  int main (int argc, char **argv) Line 295  int main (int argc, char **argv)
                     base_arg++;                      base_arg++;
                                           
                     break;                      break;
   
                   case 'E':
                       if (argv[i][2] != '=') {
                           fprintf (stderr, "fmadm:  missing equals sign in flag -%c\n", argv[i][1]);
                           fmadm_usage ();
                           exit (1);
                       }
   
                       k = 0;
                       
                       for (j = 3; j < strlen (argv[i]); j++) {
                           env_enabled[k++] = argv[i][j];
                       }
                       env_enabled[k] = '\0';
   
                       if ((strcmp (env_enabled, "true") != 0) && (strcmp (env_enabled, "false") != 0)) {
                           fprintf (stderr, "fmadm:  -E (environment enabled) option must be either 'true' or 'false'\n");
                           fmadm_usage ();
                           exit (1);
                       }
                       
                       base_arg++;
                       
                       break;
                       
                                           
                 case 'n':                  case 'n':
                     if (argv[i][2] != '=') {                      if (argv[i][2] != '=') {
Line 878  void fmadm_exit (int retval) Line 915  void fmadm_exit (int retval)
 int fmadm_usage (void)  int fmadm_usage (void)
 {  {
   
     fprintf (stdout, "\nusage:  fmadm <action> <object> [-e=<environment] [-n=<namespace>] [OPTIONS]\n");      fprintf (stdout, "\nusage:  fmadm <action> <object> [-e=<environment] [-n=<namespace>] [-u=<user>] [-g=<group>] [-E=true|false] [OPTIONS]\n");
     fprintf (stdout, "        fmadm configure\n");      fprintf (stdout, "        fmadm configure\n");
     fprintf (stdout, "        fmadm reconfigure\n");      fprintf (stdout, "        fmadm reconfigure\n");
     /* fprintf (stdout, "        fmadm checkperms\n\n"); */  
           
     fprintf (stdout, "        <action> can be one of:\n");      fprintf (stdout, "        <action> can be one of:\n");
     fprintf (stdout, "            list, examine, verify, compact, repair, create, remove,\n");      fprintf (stdout, "            list, examine, verify, compact, repair, create, remove,\n");
     fprintf (stdout, "            import, export, backup, restore, migrate, edit, start,\n");      fprintf (stdout, "            import, export, backup, restore, migrate, edit, start,\n");
     fprintf (stdout, "            stop, restart\n\n");      fprintf (stdout, "            stop, restart, status\n\n");
   
     fprintf (stdout, "        <object> can be one of:\n");      fprintf (stdout, "        <object> can be one of:\n");
     fprintf (stdout, "            lock, journal, namespace, global, routine, job,\n");      fprintf (stdout, "            lock, journal, namespace, global, routine, job,\n");
Line 1178  int fm_start_environment (char *env, cha Line 1214  int fm_start_environment (char *env, cha
 {  {
     char basecmd[255];      char basecmd[255];
     char cmd[4096];          char cmd[4096];    
   
       if (fm_environment_running (env) == TRUE) {
           return TRUE;
       }
           
 #if !defined(__OS2__)  #if !defined(__OS2__)
     snprintf (basecmd, 254, "%s/bin/freem", PREFIX);      snprintf (basecmd, 254, "%s/bin/freem", PREFIX);
Line 1186  int fm_start_environment (char *env, cha Line 1226  int fm_start_environment (char *env, cha
 #endif  #endif
   
 #if !defined(__OS2__)                      #if !defined(__OS2__)                    
     snprintf (cmd, 4095, "%s -d -e %s -u %s -g %s", basecmd, cur_env, e_user, e_grp);      snprintf (cmd, 4095, "%s -d -e %s -u %s -g %s", basecmd, env, e_user, e_grp);
 #else  #else
     sprintf (cmd, 4095, "%s -d -k -e %s -u %s -g %s", basecmd, cur_env, e_user, e_grp);      sprintf (cmd, 4095, "%s -d -k -e %s -u %s -g %s", basecmd, env, e_user, e_grp);
 #endif  #endif
   
       system (cmd);
   
       sleep (1);
           
     return (system (cmd));              return (fm_environment_running (env));
 }  }
   
 int fm_stop_environment (char *env)  int fm_stop_environment (char *env)
 {  {
     long epid;      long epid;
   
     epid = fm_get_pid (cur_env);      epid = fm_get_pid (env);
     if (epid > -1) {      if (epid > -1) {
         fprintf (stderr, "fmadm:  stopping environment daemon pid %d\n", epid);  
         kill (epid, SIGINT);          kill (epid, SIGINT);
         kill (epid, SIGTERM);          sleep (5);
   
           if (fm_environment_running (env) == FALSE) {
               return TRUE;
           }
           else {
               kill (epid, SIGTERM);
               sleep (5);
               if (fm_environment_running (env) == FALSE) {
                   return TRUE;
               }
               else {
                   kill (epid, SIGKILL);
                   sleep (5);
                   if (fm_environment_running (env) == FALSE) {
                       return TRUE;
                   }
                   else {
                       return FALSE;
                   }
               }
           }
     }      }
     else {      else {
         fprintf (stderr, "fmadm:  could not obtain environment daemon pid\n");          return FALSE;
     }         }   
 }  }
   
   int fm_environment_running (char *env)
   {       
       long epid;
       int result;
       
       epid = fm_get_pid (env);
   
       if (epid == -1) {
           return FALSE;
       }
       else {
           result = kill (epid, 0);
   
           return ((result == 0) ? TRUE : FALSE);
       }
   }
   
 int fm_daemonctl (short action, short object, int optc, char **options)  int fm_daemonctl (short action, short object, int optc, char **options)
 {  {
     FILE *ef;      FILE *ef;
Line 1289  int fm_daemonctl (short action, short ob Line 1370  int fm_daemonctl (short action, short ob
                 strcpy (e_grp, "freem");                  strcpy (e_grp, "freem");
             }              }
   
             printf ("fmadm:  %s environment %s\n", verb, cur_env);              switch (action) {
                   case ACT_START:
                   case ACT_STOP:
                   case ACT_RESTART:
                       fprintf (stderr, "fmadm:  %s environment %s... ", verb, cur_env);
                       break;
                   case ACT_STATUS:
                       fprintf (stderr, "fmadm:  %s environment %s\n", verb, cur_env);
                       break;
               }
   
             switch (action) {              switch (action) {
                                   
                 case ACT_START:                  case ACT_START:
                     result = fm_start_environment (cur_env, e_user, e_grp);                      result = fm_start_environment (cur_env, e_user, e_grp);
                       if (result == TRUE) {
                           fprintf (stderr, "[OK]\n");
                       }
                       else {
                           fprintf (stderr, "[FAIL]\n");
                       }
                     break;                      break;
   
                 case ACT_STOP:                  case ACT_STOP:
                     result = fm_stop_environment (cur_env);                      result = fm_stop_environment (cur_env);
                       if (result == TRUE) {
                           fprintf (stderr, "[OK]\n");
                       }
                       else {
                           fprintf (stderr, "[FAIL]\n");
                       }                    
                     break;                      break;
   
                 case ACT_RESTART:                  case ACT_RESTART:
                     result = fm_stop_environment (cur_env);                      if (fm_stop_environment (cur_env) == TRUE) {
                                               result = fm_start_environment (cur_env, e_user, e_grp);
                     fprintf (stderr, "fmadm:  waiting 2 seconds\n");                          if (result == TRUE) {
                     sleep (2);                              fprintf (stderr, "[OK]\n");
                     fprintf (stderr, "fmadm:  starting environment %s\n", cur_env);                          }
                           else {
                               fprintf (stderr, "[FAIL]\n");
                           }                        
                       }
                       else {
                           fprintf (stderr, "[FAIL]\n");
                       }                       
   
                     result = fm_start_environment (cur_env, e_user, e_grp);  
                     break;                      break;
                                           
                 case ACT_STATUS:                  case ACT_STATUS:
Line 1354  void fm_reconfigure(void) Line 1462  void fm_reconfigure(void)
     fprintf (stderr, "fmadm:  reconfiguring FreeM with system defaults for %s...\n", FREEM_VERSION_CSTR);      fprintf (stderr, "fmadm:  reconfiguring FreeM with system defaults for %s...\n", FREEM_VERSION_CSTR);
     fprintf (stderr, "fmadm:  backing up %s to %s...\t", config_file, config_backup);          fprintf (stderr, "fmadm:  backing up %s to %s...\t", config_file, config_backup);    
   
     retval = rename (config_file, config_backup);  #if !defined(__OS2__)    
       retval = cp (config_backup, config_file);
   #else
       retval = DosCopy (config_file, config_backup);
   #endif    
   
     if (retval == 0) {      if (retval == 0) {
         fprintf (stderr, "[OK]\n");          fprintf (stderr, "[OK]\n");
Line 1371  void fm_reconfigure(void) Line 1483  void fm_reconfigure(void)
           
 } /* fm_reconfigure() */  } /* fm_reconfigure() */
   
   void update_conf (char *file, char *section, char *key, char *new_value)
   {
       char old_value[255];
       char tbuf[255];
   
       snprintf (tbuf, 254, "%s.%s", section, key);
           
       read_profile_string (file, section, key, old_value);
       if (strcmp (old_value, new_value) != 0) {
           modify_profile_string (file, section, key, new_value);
           fprintf (stderr, "\t%-40s%-20s -> %s\n", tbuf, old_value, new_value);
       }
       else {
           fprintf (stderr, "\t%-40s%-20s\n", tbuf, "no change");
       }
   }
   
 void fm_configure (void)  void fm_configure (void)
 {  {
Line 1396  void fm_configure (void) Line 1524  void fm_configure (void)
     char buf[4096];      char buf[4096];
     FILE *fp;      FILE *fp;
   
       int reconfigure = FALSE;
       
     struct stat etcstat;      struct stat etcstat;
     int stat_result;      int stat_result;
   
Line 1406  void fm_configure (void) Line 1536  void fm_configure (void)
   
     char *username = env_user;      char *username = env_user;
     char *groupname = env_group;      char *groupname = env_group;
          
 #if !defined(__OS2__)  #if !defined(__OS2__)
     if (geteuid () != 0) {      if (geteuid () != 0) {
         fprintf (stderr, "fmadm:  not superuser\n");          fprintf (stderr, "fmadm:  not superuser\n");
Line 1449  void fm_configure (void) Line 1579  void fm_configure (void)
     }      }
           
     if (file_exists (config_file)) {      if (file_exists (config_file)) {
         fprintf (stderr, "fmadm:  '%s' already exists; running fmadm reconfigure instead\n", config_file);          reconfigure = TRUE;
         fm_reconfigure ();  
         return;  
     }      }
       
     gethostname (hostid, 4095);      gethostname (hostid, 4095);
     uuid_v4 (buf);      uuid_v4 (buf);
   
Line 1481  void fm_configure (void) Line 1609  void fm_configure (void)
   
         chmod (dstfile, 0755);          chmod (dstfile, 0755);
     }      }
 #else  
     fprintf (stderr, "fmadm:  not running on OS/2\n");  
 #endif  #endif
       
     printf ("\nFreeM Initial Configuration\n");  
     printf ("---------------------------\n\n");  
   
     printf ("This utility will create the initial configuration file for ");      if (reconfigure == FALSE) {
     printf ("FreeM environment '%s' (owned by %s:%s) in '%s'.\n\n", fma_environment, username, groupname, config_file);              printf ("\nFreeM Initial Environment Configuration\n");
           printf ("---------------------------------------\n\n");
   
           printf ("This utility will create the initial configuration files for ");
           printf ("FreeM environment '%s' (owned by %s:%s) in '%s'.\n\n", fma_environment, username, groupname, config_file);    
       }
       else {
           printf ("\nFreeM Environment Upgrade/Reconfiguration\n");
           printf ("-----------------------------------------\n\n");
   
           printf ("This utility will update the configuration files for ");
           printf ("FreeM environment '%s' (owned by %s:%s) in '%s'.\n\n", fma_environment, username, groupname, config_file);
       }
           
     /* check for existence of needed directories */      /* check for existence of needed directories */
     if (stat (SYSCONFDIR, &etcstat) == -1) {      if (stat (SYSCONFDIR, &etcstat) == -1) {
Line 1537  void fm_configure (void) Line 1672  void fm_configure (void)
           
     snprintf (src_dir, 4095, "%s/freem/mlib", DATADIR);      snprintf (src_dir, 4095, "%s/freem/mlib", DATADIR);
     snprintf (dest_dir, 4095, "%s/freem/%s/SYSTEM/routines", LOCALSTATEDIR, fma_environment);      snprintf (dest_dir, 4095, "%s/freem/%s/SYSTEM/routines", LOCALSTATEDIR, fma_environment);
       
     fprintf (stderr, "fmadm:  populating new environment '%s'\n", fma_environment);      if (reconfigure == FALSE) {
           fprintf (stderr, "fmadm:  populating new environment '%s'\n", fma_environment);
       }
       else {
           fprintf (stderr, "fmadm:  upgrading environment '%s'\n", fma_environment);
       }
           
     snprintf (buf, 4095, "%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);      snprintf (buf, 4095, "%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);
     mkdir (buf, 0775);      mkdir (buf, 0775);
Line 1603  void fm_configure (void) Line 1743  void fm_configure (void)
                   
     }      }
   
     fp = fopen (env_config_file, "a+");      if (fm_validate_environment (fma_environment) == FALSE) {
           fp = fopen (env_config_file, "a+");
     fprintf (stderr, "Creating %s... ", env_config_file);          
           fprintf (stderr, "Creating %s... ", env_config_file);
     snprintf (buf, 4095, "[%s]", fma_environment);          
     fm_write (fp, buf);          snprintf (buf, 4095, "[%s]", fma_environment);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "user=%s", env_user);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "group=%s", env_group);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "enabled=%s", env_enabled);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "env_path=%s/freem/%s", LOCALSTATEDIR, fma_environment);
           fm_write (fp, buf);
           
           fclose (fp);
           fprintf (stderr, "[OK]\n");
       }
       else {
           char modtmp[255];
           
           fprintf (stderr, "\nUpdating %s: \n", env_config_file);
   
     snprintf (buf, 4095, "user=%s", env_user);          update_conf (env_config_file, fma_environment, "user", env_user);
     fm_write (fp, buf);          update_conf (env_config_file, fma_environment, "group", env_group);
               update_conf (env_config_file, fma_environment, "enabled", env_enabled);
     snprintf (buf, 4095, "group=%s", env_group);      }
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "enabled=true");      if (reconfigure == FALSE) {
     fm_write (fp, buf);          fp = fopen (config_file, "a+");
               
     snprintf (buf, 4095, "env_path=%s/freem/%s", LOCALSTATEDIR, fma_environment);          fprintf (stderr, "Creating %s... ", config_file); 
     fm_write (fp, buf);          
               snprintf (buf, 4095, "[SYSTEM]");
     fclose (fp);          fm_write (fp, buf);
     fprintf (stderr, "[OK]\n");          
              snprintf (buf, 4095, "root=%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);
     fp = fopen (config_file, "a+");          fm_write (fp, buf);
               
     fprintf (stderr, "Creating %s... ", config_file);           snprintf (buf, 4095, "routines_path=%s", sysrtn);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "globals_path=%s", sysgbl);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "journal_file=%s", jnlfile);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "journal_mode=%s", jnlmode);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "journal_host_id=%s", jnlhostid);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "journal_cut_threshold=%s", jnlcut);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "zdate_format=%%x");
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "ztime_format=%%X");
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "\n[USER]");
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "root=%s/freem/%s/USER", LOCALSTATEDIR, fma_environment);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "routines_path=%s", usrrtn);
           fm_write (fp, buf);
           
           snprintf (buf, 4095, "globals_path=%s", usrgbl);
           fm_write (fp, buf);
           
           fclose (fp);
           set_permissions (config_file, username, groupname, 0755);
           fprintf (stderr, "[OK]\n");
           
     snprintf (buf, 4095, "[SYSTEM]");          printf ("FreeM initial configuration is complete.\n\n");
     fm_write (fp, buf);      }
       else {
     snprintf (buf, 4095, "root=%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);          char tmpsd[255];
     fm_write (fp, buf);          read_profile_string (config_file, "SYSTEM", "journal_host_id", tmpsd);
           
     snprintf (buf, 4095, "routines_path=%s", sysrtn);          /* existing configuration */
     fm_write (fp, buf);          fprintf (stderr, "\nUpdating environment configuration for %s:\n", fma_environment);
   
     snprintf (buf, 4095, "globals_path=%s", sysgbl);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "journal_file=%s", jnlfile);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "journal_mode=%s", jnlmode);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "journal_host_id=%s", jnlhostid);          snprintf (buf, 4095, "%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);
     fm_write (fp, buf);          update_conf (config_file, "SYSTEM", "root", buf);
           update_conf (config_file, "SYSTEM", "routines_path", sysrtn);       
           update_conf (config_file, "SYSTEM", "globals_path", sysgbl);
           update_conf (config_file, "SYSTEM", "journal_file", jnlfile);        
           update_conf (config_file, "SYSTEM", "journal_mode", jnlmode);
           update_conf (config_file, "SYSTEM", "journal_host_id", tmpsd);
           update_conf (config_file, "SYSTEM", "journal_cut_threshold", jnlcut);
   
     snprintf (buf, 4095, "journal_cut_threshold=%s", jnlcut);          snprintf (buf, 4095, "%%x");
     fm_write (fp, buf);          update_conf (config_file, "SYSTEM", "zdate_format", buf);
           
           snprintf (buf, 4095, "%%X");
           update_conf (config_file, "SYSTEM", "ztime_format", buf);
   
     snprintf (buf, 4095, "zdate_format=%%x");          /* USER */        
     fm_write (fp, buf);          snprintf (buf, 4095, "%s/freem/%s/USER", LOCALSTATEDIR, fma_environment);
           update_conf (config_file, "USER", "root", buf);        
           update_conf (config_file, "USER", "routines_path", usrrtn);
           update_conf (config_file, "USER", "globals_path", usrgbl);
   
     snprintf (buf, 4095, "ztime_format=%%X");      }
     fm_write (fp, buf);  
           
     snprintf (buf, 4095, "\n[USER]");  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "root=%s/freem/%s/USER", LOCALSTATEDIR, fma_environment);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "routines_path=%s", usrrtn);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "globals_path=%s", usrgbl);  
     fm_write (fp, buf);  
                   
     fclose (fp);      printf ("\n\nUSER globals:                   %s\n", usrgbl);
     set_permissions (config_file, username, groupname, 0755);      printf ("USER routines:                  %s\n", usrrtn);
     fprintf (stderr, "[OK]\n");      printf ("SYSTEM globals:                 %s\n", sysgbl);
       printf ("SYSTEM routines:                %s\n", sysrtn);
     printf ("FreeM initial configuration is complete.\n\n");      printf ("After-image journal:            %s [%s]\n", jnlfile, jnlmode);
       printf ("Journal cut threshold:          %s bytes\n", jnlcut);
     printf (" USER globals:                   %s\n", usrgbl);      printf ("Distributed journaling host ID: %s\n", jnlhostid);
     printf (" USER routines:                  %s\n", usrrtn);  
     printf (" SYSTEM globals:                 %s\n", sysgbl);  
     printf (" SYSTEM routines:                %s\n", sysrtn);  
     printf (" After-image journal:            %s [%s]\n", jnlfile, jnlmode);  
     printf (" Journal cut threshold:          %s bytes\n", jnlcut);  
     printf (" Distributed journaling host ID: %s\n", jnlhostid);  
   
       if (reconfigure == TRUE) {
           fprintf (stderr, "\nIf you previously defined environments other than '%s', you should run\n'fmadm reconfigure -e=<environment-name>' on each of them to ensure they have\nthe latest vendor routines and correct, updated settings.\n\n", fma_environment);
       }
           
 } /* fm_configure */  } /* fm_configure */
   

Removed from v.1.26  
changed lines
  Added in v.1.29


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>