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 i |
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 $(find ${MCLIBDIR}/include -type f -name \*.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 |
|
|
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 |
|
|
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 |
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" |
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="$@" |
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} |
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 |
} |
} |
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 |
|
|
|
|
|
[[ ${WEBCRLF} = true ]] && webcrlf="<br>" |
|
|
|
|
|
# respect -n |
|
|
case $1 in |
|
|
-n) shift; opts="n" ;; |
|
|
esac |
|
295 |
|
|
296 |
echo -e${opts} "${COLRED}$@${COLDEFAULT}${webcrlf}" |
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 |
# prints return values of get | enabled even in quiet mode |
print_push_config() |
|
rvecho() |
|
309 |
{ |
{ |
310 |
local COLPURPLE="\033[1;35m" |
local sorted |
|
local COLDEFAULT="\033[0m" |
|
|
local opts |
|
|
local webcrlf |
|
|
|
|
|
if [[ ${NOCOLORS} = true ]] |
|
|
then |
|
|
COLPURPLE="" |
|
|
COLDEFAULT="" |
|
|
fi |
|
|
|
|
|
[[ ${WEBCRLF} = true ]] && webcrlf="<br>" |
|
|
|
|
|
# respect -n |
|
|
case $1 in |
|
|
-n) shift; opts="n" ;; |
|
|
esac |
|
311 |
|
|
312 |
echo -e${opts} "${COLPURPLE}$@${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 debug messages if requested | enabled even in quiet mode |
push_firstboot() |
|
decho() |
|
319 |
{ |
{ |
320 |
# print nothing if debug mode was *not* requested |
local push_firstboots="$@" |
321 |
[[ ${DEBUG} != 1 ]] && return |
local i |
322 |
|
|
323 |
eecho "DEBUG: ${@}" |
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 |
path_not_empty() |
print_push_firstboot() |
336 |
{ |
{ |
337 |
local path="$1" |
local sorted |
|
[[ -z ${path} ]] && eecho "path_not_empty(): no path given!" && return 1 |
|
|
|
|
|
# return ERR if path does not exist |
|
|
[[ ! -d ${path} ]] && return 1 |
|
|
# return ERR if path empty |
|
|
[[ -z $(find "${path}" -mindepth 1 -maxdepth 1) ]] && return 1 |
|
338 |
|
|
339 |
# every thing went ok, directory not empty |
# sort them alpabetically |
340 |
return 0 |
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 |
help_daemon_mroot() |
help_daemon_mroot() |
369 |
fi |
fi |
370 |
} |
} |
371 |
|
|
|
list_files_in_directory() |
|
|
{ |
|
|
local i |
|
|
local retval |
|
|
local path |
|
|
local opts |
|
|
local type |
|
|
|
|
|
# basic getops |
|
|
for i in $* |
|
|
do |
|
|
case $1 in |
|
|
-mindepth) shift; opts+=" -mindepth $1" ;; |
|
|
-maxdepth) shift; opts+=" -maxdepth $1" ;; |
|
|
-type) shift; type="$1" ;; |
|
|
-name) shift; opts+="-name $1" ;; |
|
|
'') continue ;; |
|
|
*) path="$1" ;; |
|
|
esac |
|
|
shift |
|
|
done |
|
|
|
|
|
if [[ -z ${path} ]] |
|
|
then |
|
|
eecho "No path given." |
|
|
return 1 |
|
|
fi |
|
|
|
|
|
if [[ ! -d ${path} ]] |
|
|
then |
|
|
eecho "Directory '${path}' does not exist." |
|
|
return 1 |
|
|
fi |
|
|
|
|
|
# default to files |
|
|
[[ -z ${type} ]] && type=f |
|
|
|
|
|
for i in $(find ${path} ${opts} -type ${type} -print '%f\n' | sort) |
|
|
do |
|
|
if [[ -z ${retval} ]] |
|
|
then |
|
|
retval="${i}" |
|
|
else |
|
|
retval+=" ${i}" |
|
|
fi |
|
|
done |
|
|
|
|
|
rvecho "${retval}" |
|
|
} |
|
|
|
|
372 |
print_version() |
print_version() |
373 |
{ |
{ |
374 |
echo "mcored-$(<${MCLIBDIR}/VERSION)" |
echo "mcored-$(<${MCORE_LIBDIR}/VERSION)" |
375 |
} |
} |
|
|
|
|
system_chroot() |
|
|
{ |
|
|
local cmd="$@" |
|
|
if [[ -z ${MROOT} ]] |
|
|
then |
|
|
echo "system_chroot(): \$MROOT was not set, doing nothing!" |
|
|
return 1 |
|
|
fi |
|
|
if [ ! -d ${MROOT} ] |
|
|
then |
|
|
eecho "system_chroot(): MROOT='${MROOT}' does not exist." |
|
|
return 1 |
|
|
fi |
|
|
|
|
|
chroot ${MROOT} ${cmd} |
|
|
} |
|
|
|
|