Magellan Linux

Diff of /mcore-src/trunk/mcore-tools/src/include/daemon.global.class.in

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

mcore-src/trunk/mcore-tools/daemon/include/daemon.global.class revision 2006 by niro, Mon Aug 13 09:40:07 2012 UTC mcore-src/trunk/mcore-tools/src/include/daemon.global.class.in revision 2810 by niro, Fri Apr 7 07:30:42 2017 UTC
# Line 1  Line 1 
1  # $Id$  # $Id$
2    
3  # loads client classes from $MCLIBDIR  # loads client classes from $MCORE_LIBDIR
4  load_client_classes()  load_classes()
5  {  {
6     local class
7     local classtype
8    
9     case $1 in
10     client|control) classtype="$1" ;;
11     *) die "Unknown classes type '$1'" ;;
12     esac
13    
14   # client specific   # client specific
15   for i in ${MCLIBDIR}/include/*.client.class   for class in $(find ${MCORE_LIBDIR}/include -type f -name \*.${classtype}.class)
16   do   do
17   source ${i} || eecho "error loading ${i}"   include ${class} || eecho "error loading ${class}"
18   done   done
19  }  }
20    
# Line 26  stop_service() Line 34  stop_service()
34   local pid   local pid
35   for pid in $(pidof sslsvd)   for pid in $(pidof sslsvd)
36   do   do
37   kill -15 ${pid}   kill -SIGTERM ${pid}
  sleep 1  
  kill -9 ${pid}  
38   done   done
39  }  }
40    
# Line 52  stop_service() Line 58  stop_service()
58  # run_class $method $caller $argv1 $argv2 ... $argvN  # run_class $method $caller $argv1 $argv2 ... $argvN
59  run_class()  run_class()
60  {  {
61   local method="$1"   local method="${GLOBAL_ARGV[0]}"
62   local caller="$2"   local caller="${GLOBAL_ARGV[1]}"
63   local class   local class
64   local cmd   local cmd
65   local argv   local i
66     local count
67    
68   if valid_session   if valid_session
69   then   then
70   class="${caller%.*}"   class="${caller%.*}"
71   cmd="${caller#*.}"   cmd="${caller#*.}"
  argv="${@/${caller}/}" # remove caller  
  argv="${argv/${method}/}" # remove method  
72    
73  # echo "method=${method}"   # copy GLOBAL_ARGV to CLASS_ARGV array without method and caller.class
74  # echo "caller=${caller}"   unset CLASS_ARGV
75  # echo "class=${class}"   count="${#GLOBAL_ARGV[*]}"
76  # echo "cmd=${cmd}"   for (( i=2; i<count; i++ ))
77  # echo "argv=${argv}"   do
78     CLASS_ARGV[${i}-2]="${GLOBAL_ARGV[${i}]}"
79     done
80    
81    # decho "method=${method}"
82    # decho "caller=${caller}"
83    # decho "class=${class}"
84    # decho "cmd=${cmd}"
85    # decho "class argv=$(printf '\"%s\" ' ${CLASS_ARGV[*]}; printf '\n')"
86    
87   # check if class.cmd exist   # check if class.cmd exist
88   if [[ ! -z $(typeset -f "${method}"_"${class}"_"${cmd}") ]]   if [[ ! -z $(typeset -f "${method}"_"${class}"_"${cmd}") ]]
89   then   then
90   "${method}"_"${class}"_"${cmd}" ${argv}   "${method}"_"${class}"_"${cmd}"
91   else   else
92   eecho "unkown method '${method}' . class '${class}' . cmd '${cmd}'"   eecho "unknown method '${method}' . class '${class}' . cmd '${cmd}'"
93   fi   fi
94   else   else
95   invalid_session   invalid_session
96   fi   fi
97  }  }
98    
99    run_push_config()
100    {
101     local serial="$1"
102     local config
103    
104     if [[ -z ${serial} ]]
105     then
106     eecho "missing serial"
107     return 1
108     fi
109    
110     for config in $(NOCOLORS=1 print_push_config)
111     do
112     if [[ -n $(typeset -f push_config_${config}) ]]
113     then
114     decho "running: 'push_config_${config} ${serial}'"
115     push_config_"${config}" "${serial}"
116     else
117     decho "no function 'push_config_${config}' for '${config}' found."
118     fi
119     done
120    }
121    
122    run_push_firstboot()
123    {
124     local serial="$1"
125     local config
126    
127     if [[ -z ${serial} ]]
128     then
129     eecho "missing serial"
130     return 1
131     fi
132    
133     for config in $(NOCOLORS=1 print_push_firstboot)
134     do
135     if [[ -n $(typeset -f push_firstboot_${config}) ]]
136     then
137     decho "running: 'push_firstboot_${config} ${serial}'"
138     push_firstboot_"${config}" "${serial}"
139     else
140     decho "no function 'push_firstboot_${config}' for '${config}' found."
141     fi
142     done
143    }
144    
145  help_topics()  help_topics()
146  {  {
147   local i   local i
# Line 94  help_topics() Line 153  help_topics()
153   mecho "\tget      - shows current value for a settings"   mecho "\tget      - shows current value for a settings"
154   mecho "\tset      - sets value for a setting"   mecho "\tset      - sets value for a setting"
155   mecho "\tauth     - authenticate to the daemon"   mecho "\tauth     - authenticate to the daemon"
156     mecho "\tcertauth - authenticate to the daemon via fingerprint"
157   mecho "\tprovide  - shows provides of a system"   mecho "\tprovide  - shows provides of a system"
158   mecho "\trequire  - verify plugin requirements"   mecho "\trequire  - verify plugin requirements"
159   mecho "\treload   - reloads all client classes plugins"   mecho "\treload   - reloads all client classes plugins"
# Line 103  help_topics() Line 163  help_topics()
163   mecho "\tcolors   - enable colors"   mecho "\tcolors   - enable colors"
164   mecho "\tquiet    - do not print any unecessary messages"   mecho "\tquiet    - do not print any unecessary messages"
165   mecho "\thelp     - shows help"   mecho "\thelp     - shows help"
166     mecho "\tversion  - prints version of the daemon"
167   mecho "\tquit     - quits the connection to the server"   mecho "\tquit     - quits the connection to the server"
168   mecho   mecho
169   mecho "Help topics:"   mecho "Help topics:"
# Line 119  help_topics() Line 180  help_topics()
180   mecho "Type 'help [topic]' for more information about every topic."   mecho "Type 'help [topic]' for more information about every topic."
181  }  }
182    
 # on newer xorg-servers root is not allowed to run progs in a user session  
 x11runas()  
 {  
  if [[ -n $(pidof X) ]]  
  then  
  su - "${MCORE_UNPRIV_USER}" -c "DISPLAY=${MCORE_XORG_DISPLAY} $@"  
  fi  
 }  
   
 addconfig()  
 {  
  local opts  
   
  if [[ -z ${CONFIG} ]]  
  then  
  eecho "You must define \$CONFIG varibale first!"  
  return 1  
  fi  
   
  if [[ ! -d $(dirname ${CONFIG}) ]]  
  then  
  install -d $(dirname ${CONFIG})  
  fi  
   
  # check for opts  
  case $1 in  
  -n) shift; opts=" -n" ;;  
  -e) shift; opts=" -e" ;;  
  esac  
   
  echo ${opts} "$@" >> ${CONFIG}  
 }  
   
 clearconfig()  
 {  
  if [[ -z ${CONFIG} ]]  
  then  
  eecho "You must define \$CONFIG varibale first!"  
  return 1  
  fi  
   
  if [[ ! -d $(dirname ${CONFIG}) ]]  
  then  
  install -d $(dirname ${CONFIG})  
  fi  
  : > ${CONFIG}  
 }  
   
 # no_duplicate $list $item  
 no_duplicate()  
 {  
  local i  
  local list="$1"  
  local item="$2"  
   
  for i in ${list}  
  do  
  [[ ${i} = ${item} ]] && return 1  
  done  
   
  return 0  
 }  
   
183  require()  require()
184  {  {
185   local requires="$@"   local requires="$@"
# Line 189  require() Line 187  require()
187    
188   for i in ${requires}   for i in ${requires}
189   do   do
190   # check for duplicate provides   # check for duplicate require
191   if no_duplicate "${PROVIDE}" "${i}"   if no_duplicate "${REQUIRE}" "${i}"
192   then   then
193   export REQUIRE="${REQUIRE} ${i}"   export REQUIRE="${REQUIRE} ${i}"
194   else   else
195   decho "duplicate provide '${i}' detected!"   decho "duplicate require '${i}' detected!"
196   fi   fi
197   done   done
198  }  }
# Line 223  verify_requirements() Line 221  verify_requirements()
221   # show missing and set the right retval   # show missing and set the right retval
222   if [[ -z ${missing} ]]   if [[ -z ${missing} ]]
223   then   then
224   rvecho "${sorted}"   # do not escape, or CRLFS get printed to screen too
225     rvecho ${sorted}
226   return 0   return 0
227   else   else
228   for req in ${sorted}   for req in ${sorted}
# Line 231  verify_requirements() Line 230  verify_requirements()
230   if no_duplicate "${missing}" "$req"   if no_duplicate "${missing}" "$req"
231   then   then
232   # print normal   # print normal
233   rvecho -n " ${req}"   rvecho -n "${req} "
234   else   else
235   # print missing   # print missing
236   eecho -n " ${req}"   eecho -n "${req} "
237   fi   fi
238   done   done
239     # print CRLF
240     echo
241   return 1   return 1
242   fi   fi
243  }  }
# Line 268  print_provide() Line 269  print_provide()
269   rvecho ${sorted}   rvecho ${sorted}
270  }  }
271    
272  # message only echo | disabled in quiet mode  is_provided()
 mecho()  
273  {  {
274   local COLCYAN="\033[1;36m"   local feature="$1"
275   local COLDEFAULT="\033[0m"   local i
276   local opts   local retval
  local webcrlf  
   
  # print nothing if quiet mode was requested  
  [[ ${QUIET} = true ]] && return  
   
  if [[ ${NOCOLORS} = true ]]  
  then  
  COLCYAN=""  
  COLDEFAULT=""  
  fi  
   
  [[ ${WEBCRLF} = true ]] && webcrlf="<br>"  
277    
278   # respect -n   retval=1
279   case $1 in   for i in $(print_provide)
280   -n) shift; opts="n" ;;   do
281   esac   if [[ ${i} = ${feature} ]]
282     then
283     retval=0
284     break
285     fi
286     done
287    
288   echo -e${opts} "${COLCYAN}$@${COLDEFAULT}${webcrlf}"   return "${retval}"
289  }  }
290    
291  # prints error messages | enabled even in quiet mode  push_config()
 eecho()  
292  {  {
293   local COLRED="\033[1;31m"   local push_configs="$@"
294   local COLDEFAULT="\033[0m"   local i
  local opts  
  local webcrlf  
   
  if [[ ${NOCOLORS} = true ]]  
  then  
  COLRED=""  
  COLDEFAULT=""  
  fi  
295    
296   [[ ${WEBCRLF} = true ]] && webcrlf="<br>"   for i in ${push_configs}
297     do
298     # check for duplicate provides
299     if no_duplicate "${PUSH_CONFIG}" "${i}"
300     then
301     export PUSH_CONFIG="${PUSH_CONFIG} ${i}"
302     else
303     decho "duplicate push_config '${i}' detected!"
304     fi
305     done
306    }
307    
308   # respect -n  print_push_config()
309   case $1 in  {
310   -n) shift; opts="n" ;;   local sorted
  esac  
311    
312   echo -e${opts} "${COLRED}$@${COLDEFAULT}${webcrlf}"   # sort them alpabetically
313     sorted=$(for i in ${PUSH_CONFIG}; do echo "${i}"; done | sort)
314     # do not escape, or CRLFS get printed to screen too
315     rvecho ${sorted}
316  }  }
317    
318  # prints return values of get | enabled even in quiet mode  push_firstboot()
 rvecho()  
319  {  {
320   local COLPURPLE="\033[1;35m"   local push_firstboots="$@"
321   local COLDEFAULT="\033[0m"   local i
  local opts  
  local webcrlf  
   
  if [[ ${NOCOLORS} = true ]]  
  then  
  COLPURPLE=""  
  COLDEFAULT=""  
  fi  
322    
323   [[ ${WEBCRLF} = true ]] && webcrlf="<br>"   for i in ${push_firstboots}
324     do
325     # check for duplicate provides
326     if no_duplicate "${PUSH_FIRSTBOOT}" "${i}"
327     then
328     export PUSH_FIRSTBOOT="${PUSH_FIRSTBOOT} ${i}"
329     else
330     decho "duplicate push_firstboot '${i}' detected!"
331     fi
332     done
333    }
334    
335   # respect -n  print_push_firstboot()
336   case $1 in  {
337   -n) shift; opts="n" ;;   local sorted
  esac  
338    
339   echo -e${opts} "${COLPURPLE}$@${COLDEFAULT}${webcrlf}"   # sort them alpabetically
340     sorted=$(for i in ${PUSH_FIRSTBOOT}; do echo "${i}"; done | sort)
341     # do not escape, or CRLFS get printed to screen too
342     rvecho ${sorted}
343  }  }
344    
345  # prints debug messages if requested | enabled even in quiet mode  help_daemon_mroot()
 decho()  
346  {  {
347   # print nothing if debug mode was *not* requested   mecho "get daemon.mroot"
348   [[ ${DEBUG} != 1 ]] && return   mecho " Prints current MROOT variable."
349     mecho
350     mecho "set daemon.mroot [path]"
351     mecho " set MROOT variable to given path."
352    }
353    
354   eecho "DEBUG: ${@}"  get_daemon_mroot()
355    {
356     rvecho "${MROOT}"
357  }  }
358    
359  path_not_empty()  set_daemon_mroot()
360  {  {
361   local path="$1"   local path=$1
  [[ -z ${path} ]] && eecho "path_not_empty(): no path given!" && return 1  
362    
363   # return ERR if path does not exist   if [[ -d ${path} ]]
364   [[ ! -d ${path} ]] && return 1   then
365   # return ERR if path empty   export MROOT="${path}"
366   [[ -z $(find "${path}" -mindepth 1 -maxdepth 1) ]] && return 1   decho "MROOT='${MROOT}' is set."
367     else
368     eecho "Path '${path}' does not exist. MROOT not set."
369     fi
370    }
371    
372   # every thing went ok, directory not empty  print_version()
373   return 0  {
374     echo "mcored-$(<${MCORE_LIBDIR}/VERSION)"
375  }  }

Legend:
Removed from v.2006  
changed lines
  Added in v.2810