--- mcore-src/trunk/mcore-tools/src/include/register.global.class.in 2015/09/03 13:28:24 2442 +++ mcore-src/trunk/mcore-tools/src/include/register.global.class.in 2015/09/11 09:56:34 2507 @@ -6,7 +6,9 @@ local ip_address="$2" local serial local mtime - local cmd + local serial_id + local os + local tools if [[ -z ${mac_address} ]] then @@ -21,14 +23,16 @@ fi decho "registering mac_address='${mac_address}'" + decho "registering ip_address='${ip_address}'" # first check if mac is registered serial=$(mysqldo "select serial from client_serials where mac='${mac_address}'") + # current mtime + mtime=$(date +%s) + if [[ -z ${serial} ]] then - mtime=$(date +%s) - # request a new serial; one command now (cause must be done in the same session) serial=$(mysqldo "insert into client_serials (mtime, mac) values('${mtime}','${mac_address}'); select last_insert_id();") fi @@ -40,11 +44,36 @@ decho "serial='${serial}'" rvecho "${serial}" - cmd+="quiet" - cmd+="register '${serial}'" - SSLSAY_IP="${IP}" + SSLSAY_IP="${ip_address}" SSLSAY_PORT="6666" - nsslsay_fingerprint "${cmd}" + nsslsay_fingerprint "register '${serial}'" + + # register the client as online + serial_id=$(mysqldo "select serial from state_connected where serial=${serial};") + if [[ -n ${serial_id} ]] + then + mysqldo "update state_connected set ip='${ip_address}', mac='${mac_address}', mtime='${mtime}' where serial=${serial};" + else + mysqldo "insert into state_connected(serial,ip,mac,mtime) values('${serial}','${ip_address}','${mac_address}','${mtime}');" + fi + + # update tools and os version info + nsslsay_queue_init + nsslsay_queue_add "nocolors" + nsslsay_queue_add "get version.os" + os=$(control_client "${serial}" run-queue) + import_resource client_version "${serial}" os "${os}" + nsslsay_queue_init + nsslsay_queue_add "nocolors" + nsslsay_queue_add "get version.tools" + tools=$(control_client "${serial}" run-queue) + import_resource client_version "${serial}" utils "${tools}" + + # run hardware detection + if is_provided hardware + then + run_hardware_detect "${serial}" + fi return 0 fi @@ -56,7 +85,6 @@ local iface_ip local iface local mac_address - local cmd control_server_ip=$(dns_to_ip ${MCORE_CONTROL_SERVER}) iface_ip=$(iface_for_remote_addr ${control_server_ip}) @@ -69,10 +97,7 @@ decho "mac_address='${mac_address}'" decho "register '${mac_address}'" - - cmd+="quiet" - cmd+="register '${mac_address}' '${iface_ip}'" - nsslsay_fingerprint "${cmd}" + nsslsay_fingerprint "register '${mac_address}' '${iface_ip}'" } register_client_local() @@ -85,6 +110,7 @@ return 1 fi + install -d "${MCORE_CONFIG_PATH}" CONFIG="${MCORE_CONFIG_PATH}/serial" clearconfig addconfig "CLIENT_SERIAL=\"${serial}\""