Diff for /freem/src/fmadm.c between versions 1.28 and 1.30

version 1.28, 2025/04/02 19:59:38 version 1.30, 2025/04/03 20:48:14
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.30  2025/04/03 20:48:14  snw
    *   Improve daemon error diagnostics and bump to 0.63.0-rc3
    *
    *   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   *   Revision 1.28  2025/04/02 19:59:38  snw
  *   Automatically modify env.conf from fmadm reconfigure   *   Automatically modify env.conf from fmadm reconfigure
  *   *
Line 174  extern char config_file[4096]; Line 180  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 204  int main (int argc, char **argv) Line 211  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 290  int main (int argc, char **argv) Line 298  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 885  void fmadm_exit (int retval) Line 918  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 1276  int fm_daemonctl (short action, short ob Line 1308  int fm_daemonctl (short action, short ob
     char *savptr;      char *savptr;
     int result;      int result;
     long epid;      long epid;
       int retval;
         
       retval = 0;
           
     switch (action) {      switch (action) {
         case ACT_START:          case ACT_START:
Line 1371  int fm_daemonctl (short action, short ob Line 1405  int fm_daemonctl (short action, short ob
                     }                      }
                     else {                      else {
                         fprintf (stderr, "[FAIL]\n");                          fprintf (stderr, "[FAIL]\n");
                           retval++;
                     }                                          }                    
                     break;                      break;
   
Line 1382  int fm_daemonctl (short action, short ob Line 1417  int fm_daemonctl (short action, short ob
                         }                          }
                         else {                          else {
                             fprintf (stderr, "[FAIL]\n");                              fprintf (stderr, "[FAIL]\n");
                               retval++;
                         }                                                  }                        
                     }                      }
                     else {                      else {
                         fprintf (stderr, "[FAIL]\n");                          fprintf (stderr, "[FAIL]\n");
                           retval++;
                     }                                             }                       
   
                     break;                      break;
Line 1406  int fm_daemonctl (short action, short ob Line 1443  int fm_daemonctl (short action, short ob
     } while ((cur_env = strtok_r (NULL, ",", &savptr)) != NULL);      } while ((cur_env = strtok_r (NULL, ",", &savptr)) != NULL);
   
     free (envlist);      free (envlist);
     exit (0);      exit (retval);
           
 } /* fm_daemonctl() */  } /* fm_daemonctl() */
   
Line 1433  void fm_reconfigure(void) Line 1470  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 1450  void fm_reconfigure(void) Line 1491  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 1475  void fm_configure (void) Line 1532  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 1528  void fm_configure (void) Line 1587  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 1560  void fm_configure (void) Line 1617  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 1616  void fm_configure (void) Line 1680  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 1696  void fm_configure (void) Line 1765  void fm_configure (void)
         snprintf (buf, 4095, "group=%s", env_group);          snprintf (buf, 4095, "group=%s", env_group);
         fm_write (fp, buf);          fm_write (fp, buf);
                   
         snprintf (buf, 4095, "enabled=true");          snprintf (buf, 4095, "enabled=%s", env_enabled);
         fm_write (fp, buf);          fm_write (fp, buf);
                   
         snprintf (buf, 4095, "env_path=%s/freem/%s", LOCALSTATEDIR, fma_environment);          snprintf (buf, 4095, "env_path=%s/freem/%s", LOCALSTATEDIR, fma_environment);
Line 1708  void fm_configure (void) Line 1777  void fm_configure (void)
     else {      else {
         char modtmp[255];          char modtmp[255];
                   
         fprintf (stderr, "Updating %s: \n", env_config_file);          fprintf (stderr, "\nUpdating %s: \n", env_config_file);
           
         read_profile_string (env_config_file, fma_environment, "user", modtmp);  
         if (strcmp (env_user, modtmp) != 0) {  
             modify_profile_string (env_config_file, fma_environment, "user", env_user);  
             fprintf (stderr, "\tuser:   %s -> %s\n", modtmp, env_user);  
         }  
   
         read_profile_string (env_config_file, fma_environment, "group", modtmp);          update_conf (env_config_file, fma_environment, "user", env_user);
         if (strcmp (env_group, modtmp) != 0) {          update_conf (env_config_file, fma_environment, "group", env_group);
             modify_profile_string (env_config_file, fma_environment, "group", env_group);          update_conf (env_config_file, fma_environment, "enabled", env_enabled);
             fprintf (stderr, "\tgroup:  %s -> %s\n", modtmp, env_group);  
         }  
     }      }
      
     fp = fopen (config_file, "a+");  
       
     fprintf (stderr, "Creating %s... ", config_file);   
       
     snprintf (buf, 4095, "[SYSTEM]");  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "root=%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);  
     fm_write (fp, buf);  
   
     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);      if (reconfigure == FALSE) {
     fm_write (fp, buf);          fp = fopen (config_file, "a+");
           
     snprintf (buf, 4095, "zdate_format=%%x");          fprintf (stderr, "Creating %s... ", config_file); 
     fm_write (fp, buf);          
           snprintf (buf, 4095, "[SYSTEM]");
     snprintf (buf, 4095, "ztime_format=%%X");          fm_write (fp, buf);
     fm_write (fp, buf);          
           snprintf (buf, 4095, "root=%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);
           fm_write (fp, buf);
           
           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, "\n[USER]");          printf ("FreeM initial configuration is complete.\n\n");
     fm_write (fp, buf);      }
       else {
     snprintf (buf, 4095, "root=%s/freem/%s/USER", 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", usrrtn);  
     fm_write (fp, buf);  
   
     snprintf (buf, 4095, "globals_path=%s", usrgbl);  
     fm_write (fp, buf);  
                   
     fclose (fp);          /* existing configuration */
     set_permissions (config_file, username, groupname, 0755);          fprintf (stderr, "\nUpdating environment configuration for %s:\n", fma_environment);
     fprintf (stderr, "[OK]\n");  
   
     printf ("FreeM initial configuration is complete.\n\n");          snprintf (buf, 4095, "%s/freem/%s/SYSTEM", LOCALSTATEDIR, fma_environment);
           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, "%%x");
           update_conf (config_file, "SYSTEM", "zdate_format", buf);
           
           snprintf (buf, 4095, "%%X");
           update_conf (config_file, "SYSTEM", "ztime_format", buf);
   
           /* USER */        
           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);
   
     printf (" USER globals:                   %s\n", usrgbl);      }
     printf (" USER routines:                  %s\n", usrrtn);      
     printf (" SYSTEM globals:                 %s\n", sysgbl);          
     printf (" SYSTEM routines:                %s\n", sysrtn);      printf ("\n\nUSER globals:                   %s\n", usrgbl);
     printf (" After-image journal:            %s [%s]\n", jnlfile, jnlmode);      printf ("USER routines:                  %s\n", usrrtn);
     printf (" Journal cut threshold:          %s bytes\n", jnlcut);      printf ("SYSTEM globals:                 %s\n", sysgbl);
     printf (" Distributed journaling host ID: %s\n", jnlhostid);      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.28  
changed lines
  Added in v.1.30


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