diff --git a/src/lib66/ssexec_disable.c b/src/lib66/ssexec_disable.c index d773265d75176c121e53d93025b6da932133e83b..980a15dfcddcef33b66e5486ee6700928906e9da 100644 --- a/src/lib66/ssexec_disable.c +++ b/src/lib66/ssexec_disable.c @@ -14,6 +14,7 @@ #include <string.h> #include <errno.h> +#include <stdint.h> #include <oblibs/obgetopt.h> #include <oblibs/log.h> @@ -33,6 +34,7 @@ #include <66/utils.h> static stralloc workdir = STRALLOC_ZERO ; +static uint8_t FORCE = 0 ; static void cleanup(void) { @@ -62,22 +64,32 @@ int svc_remove(genalloc *tostop,ss_resolve_t *res, char const *src,ssexec_t *inf if (!stralloc_cats(&dst,SS_SVC)) goto err ; } else if (!stralloc_cats(&dst,SS_DB SS_SRC)) goto err ; + if (!stralloc_cats(&dst,"/")) goto err ; + newlen = dst.len ; - if (!ss_resolve_add_rdeps(&rdeps,&cp,src)) + if (!FORCE) { - log_warnusys("resolve recursive dependencies of: ",name) ; - goto err ; - } - ss_resolve_free(&cp) ; + if (!ss_resolve_add_rdeps(&rdeps,&cp,src)) + { + log_warnusys("resolve recursive dependencies of: ",name) ; + goto err ; + } - if (!ss_resolve_add_logger(&rdeps,src)) + if (!ss_resolve_add_logger(&rdeps,src)) + { + log_warnusys("resolve logger") ; + goto err ; + } + } + else { - log_warnusys("resolve logger") ; - goto err ; + if (!ss_resolve_append(&rdeps,&cp)) goto err ; } + ss_resolve_free(&cp) ; + for (;i < genalloc_len(ss_resolve_t,&rdeps) ; i++) { ss_resolve_t_ref pres = &genalloc_s(ss_resolve_t,&rdeps)[i] ; @@ -142,26 +154,27 @@ int svc_remove(genalloc *tostop,ss_resolve_t *res, char const *src,ssexec_t *inf int ssexec_disable(int argc, char const *const *argv,char const *const *envp,ssexec_t *info) { int r, logname ; - unsigned int nlongrun, nclassic, stop ; + unsigned int nlongrun, nclassic, stop, force ; genalloc tostop = GENALLOC_ZERO ;//ss_resolve_t genalloc gares = GENALLOC_ZERO ; //ss_resolve_t ss_resolve_t res = RESOLVE_ZERO ; ss_resolve_t_ref pres ; - r = nclassic = nlongrun = stop = logname = 0 ; + r = nclassic = nlongrun = stop = logname = force = 0 ; { subgetopt_t l = SUBGETOPT_ZERO ; for (;;) { - int opt = getopt_args(argc,argv, ">S", &l) ; + int opt = getopt_args(argc,argv, ">SF", &l) ; if (opt == -1) break ; if (opt == -2) log_die(LOG_EXIT_USER,"options must be set first") ; switch (opt) { - case 'S' : stop = 1 ; break ; + case 'S' : if (FORCE) log_usage(usage_disable) ; stop = 1 ; break ; + case 'F' : if (stop) log_usage(usage_disable) ; FORCE = 1 ; break ; default : log_usage(usage_disable) ; } } @@ -194,12 +207,21 @@ int ssexec_disable(int argc, char const *const *argv,char const *const *envp,sse pres = &genalloc_s(ss_resolve_t,&gares)[i] ; char *string = pres->sa.s ; char *name = string + pres->name ; + char *state = string + pres->state ; uint8_t found = 0 ; char module_name[256] ; + + /** The force options can be only used if the service is not marked initialized. + * This option should only be used when we have a inconsistent state between + * the /var/lib/66/system/<tree>/servicedirs/* and /var/lib/66/system/<tree>/.resolve + * directory meaning a service which is not present in the compiled db but its resolve file + * exist.*/ + if (FORCE && ss_state_check(state,name)) + log_die_nclean(LOG_EXIT_USER,&cleanup,name," is marked initialized -- it's not allowed to force to disable it") ; if (!module_search_service(workdir.s,&gares,name,&found,module_name)) log_dieu_nclean(LOG_EXIT_SYS,&cleanup,"search in module") ; - if (found) log_die_nclean(LOG_EXIT_USER,&cleanup,name," is a part of: ",module_name," module -- it's not allowed to disable it alone") ; + if (found && !FORCE) log_die_nclean(LOG_EXIT_USER,&cleanup,name," is a part of: ",module_name," module -- it's not allowed to disable it alone") ; logname = 0 ; if (obstr_equal(name,SS_MASTER + 1)) @@ -209,7 +231,7 @@ int ssexec_disable(int argc, char const *const *argv,char const *const *envp,sse if (logname > 0 && (!ss_resolve_cmp(&gares,string + pres->logassoc))) log_die_nclean(LOG_EXIT_USER,&cleanup,"logger detected - disabling is not allowed") ; - if (!pres->disen) + if (!pres->disen && !FORCE) { log_info(name,": is already disabled") ; continue ;