Contents of /mcore-src/trunk/mcore-tools/src/mcore-controld.in
Parent Directory | Revision Log
Revision 2438 -
(show annotations)
(download)
Thu Sep 3 12:50:25 2015 UTC (9 years ago) by niro
File size: 3314 byte(s)
Thu Sep 3 12:50:25 2015 UTC (9 years ago) by niro
File size: 3314 byte(s)
-added missing mcore.conf include
1 | #!/bin/sh |
2 | |
3 | MCORE_LIBDIR="@@MCORE_LIBDIR@@" |
4 | |
5 | # respect system env (proxy settings etc) |
6 | if [ -e @@SYSCONFDIR@@/profile ] |
7 | then |
8 | source @@SYSCONFDIR@@/profile |
9 | fi |
10 | |
11 | # globals |
12 | # include function comes with common.global class |
13 | source ${MCORE_LIBDIR}/include/common.global.class |
14 | include ${MCORE_LIBDIR}/include/daemon.global.class |
15 | include ${MCORE_LIBDIR}/include/sessionauth.global.class |
16 | include ${MCORE_LIBDIR}/include/mysqlfunctions.global.class |
17 | #include ${MCORE_LIBDIR}/include/hwdetection.global.class |
18 | |
19 | # load control classes plugins |
20 | load_classes control |
21 | |
22 | # config settings |
23 | include @@SYSCONFDIR@@/mcore/mcore.conf |
24 | |
25 | SQL_USER=alx |
26 | SQL_PASS=@lx |
27 | SQL_HOST=localhost |
28 | SQL_DB=alx_web |
29 | |
30 | import_resource() |
31 | { |
32 | local table="$1" |
33 | local serial="$2" |
34 | local resource="$3" |
35 | local value="$4" |
36 | |
37 | if [[ ${DEBUG} = 1 ]] |
38 | then |
39 | echo "${table}->${resource}=${value}" >> /root/lala.log |
40 | echo "mysqldo \"update ${table} set ${resource}='${value}' where serial=${serial};\"" >> /root/lala.log |
41 | fi |
42 | |
43 | mysql_insert "${table}",serial="${serial}","${resource}"="${value}" |
44 | } |
45 | |
46 | nsslsay() |
47 | { |
48 | nssl "${IP}" "${PORT}" << EOF |
49 | auth ${SSLSAY_USER} ${SSLSAY_PASS} |
50 | $@ |
51 | quit |
52 | EOF |
53 | } |
54 | |
55 | control_client() |
56 | { |
57 | local serial="$1" |
58 | local command="${@/$1/}" |
59 | local IP |
60 | |
61 | IP=$(mysqldo "select ip from state_connected where serial='${serial}'") |
62 | if [[ -z ${IP} ]] |
63 | then |
64 | echo "no ip found for client '${serial}'" |
65 | return 1 |
66 | fi |
67 | |
68 | nsslsay "${command}" |
69 | } |
70 | |
71 | #IP="192.168.0.6" |
72 | PORT="6666" |
73 | SSLSAY_USER="foo" |
74 | SSLSAY_PASS="bar" |
75 | |
76 | DEBUG=1 |
77 | NOCOLORS="false" |
78 | WEBCRLF="false" |
79 | QUIET="false" |
80 | |
81 | # argvs are global variables - this fixes issues with whitespaces |
82 | # global argvs, the whole command line |
83 | export GLOBAL_ARGV |
84 | # class specific argvs which are given to the class as parameters |
85 | export CLASS_ARGV |
86 | |
87 | run=run |
88 | valid_session=no |
89 | |
90 | # tell what we are |
91 | echo "Connected to $(print_version)" |
92 | |
93 | while [[ ${run} = run ]] |
94 | do |
95 | # use an echo here not read -p '>' because sslsvd ignores the prompt pattern |
96 | echo -n '> ' |
97 | read line |
98 | eval "GLOBAL_ARGV=( ${line} )" |
99 | |
100 | case ${GLOBAL_ARGV[0]} in |
101 | quit) run=quit ;; |
102 | |
103 | # only react on the globals -> import|get|set|auth |
104 | import) run_class ;; |
105 | control) run_class ;; |
106 | get) run_class ;; |
107 | set) run_class ;; |
108 | auth) validate_auth ${GLOBAL_ARGV[*]:1} ;; |
109 | certauth) validate_auth_certificate ${GLOBAL_ARGV[*]:1} ;; |
110 | register) valid_session && validate_client ${GLOBAL_ARGV[*]:1} ;; |
111 | provide) valid_session && print_provide ;; |
112 | require) valid_session && verify_requirements ;; |
113 | reload) valid_session && mecho "reloading client classes ..." && load_classes client ;; |
114 | restart) valid_session && restart_service ;; |
115 | stop) valid_session && stop_service ;; |
116 | nocolors) export NOCOLORS="true" ;; |
117 | colors) export NOCOLORS="false" ;; |
118 | webcrlf) export WEBCRLF="true" ;; |
119 | quiet) export QUIET="true" ;; |
120 | # version does not need auth |
121 | version) print_version ;; |
122 | help) |
123 | if valid_session |
124 | then |
125 | if [[ ${line} = help ]] |
126 | then |
127 | help_topics |
128 | else |
129 | run_class ${line} |
130 | fi |
131 | else |
132 | mecho "You must authenticate yourself first!" |
133 | mecho " auth [username] [password]" |
134 | mecho "or" |
135 | mecho " certauth [certificate fingerprint]" |
136 | fi |
137 | ;; |
138 | |
139 | *) |
140 | mecho "Unknown command '${line}'" |
141 | mecho "Type 'help' for more information." |
142 | #echo "$line" >> /root/lala.log |
143 | ;; |
144 | esac |
145 | |
146 | # unset argvs to be safe |
147 | unset GLOBAL_ARGS |
148 | unset CLASS_ARGS |
149 | done |
Properties
Name | Value |
---|---|
svn:executable | * |