2011-08-18 Sergio Martin <sergio.martin@artica.es>

* win32/windows/pandora_windows_info.h
	win32/windows/pandora_wmi.cc
	win32/windows/pandora_wmi.h
	win32/windows/pandora_windows_info.cc
	win32/bin/PandoraAgent.exe
	win32/bin/pandora_agent.conf
	win32/pandora_windows_service.cc: Added to the windows agent
	the address token with manual (specified address) and auto 
	(detecting from WMI the address) modes



git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4763 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
zarzuelo 2011-08-18 09:41:37 +00:00
parent 5215fbb641
commit c35cb15176
8 changed files with 84 additions and 1 deletions

View File

@ -1,3 +1,15 @@
2011-08-18 Sergio Martin <sergio.martin@artica.es>
* win32/windows/pandora_windows_info.h
win32/windows/pandora_wmi.cc
win32/windows/pandora_wmi.h
win32/windows/pandora_windows_info.cc
win32/bin/PandoraAgent.exe
win32/bin/pandora_agent.conf
win32/pandora_windows_service.cc: Added to the windows agent
the address token with manual (specified address) and auto
(detecting from WMI the address) modes
2011-08-10 Vanessa Gil <vanessa.gil@artica.es>
* unix/pandora_agent.php: Fixed error reading collections of the configuration file.

View File

@ -29,6 +29,12 @@ temporal "$AgentTemp$"
# agent_name My_Custom_Agent_name
# address: Enforce to server a ip address to this agent
# You can also try to detect the first IP using "auto", for example
#address auto
# or setting a fixed IP address, like for example:
#address 192.168.36.73
# Group assigned for this agent (descriptive, p.e: Servers)
#group Servers

View File

@ -356,7 +356,7 @@ Pandora_Windows_Service::lauchTentacleProxy() {
string
Pandora_Windows_Service::getXmlHeader () {
char timestamp[20];
string agent_name, os_name, os_version, encoding, value, xml;
string agent_name, os_name, os_version, encoding, value, xml, address;
time_t ctime;
struct tm *ctime_tm = NULL;
@ -398,6 +398,19 @@ Pandora_Windows_Service::getXmlHeader () {
xml += timestamp;
}
// Get agent address
address = conf->getValue ("address");
if (address != "") {
if(address == "auto") {
address = Pandora_Windows_Info::getSystemAddress ();
}
if(address != "") {
xml += "\" address=\"";
xml += address;
}
}
xml += "\" interval=\"" + conf->getValue ("interval") +
"\" os_name=\"" + os_name +
"\" os_version=\"" + os_version +

View File

@ -67,6 +67,16 @@ Pandora_Windows_Info::getSystemName () {
return Pandora_Wmi::getSystemName ();
}
/**
* Get the address of the running system.
*
* @return The system IP address.
*/
string
Pandora_Windows_Info::getSystemAddress () {
return Pandora_Wmi::getSystemAddress ();
}
/**
* Get the system path of the running operating system.
*

View File

@ -38,6 +38,7 @@ namespace Pandora_Windows_Info {
string getOSVersion ();
string getOSBuild ();
string getSystemName ();
string getSystemAddress ();
string getSystemPath ();
HANDLE *getProcessHandles (string name, int *num_procs);
string getRegistryValue (HKEY root, const string treepath, const string keyname);

View File

@ -1188,3 +1188,43 @@ Pandora_Wmi::getServices (list<string> &rows) {
}
return num_objects;
}
/**
* Get the system address
*
* @return The system address
*/
string
Pandora_Wmi::getSystemAddress () {
CDhInitialize init;
CDispPtr wmi_svc = NULL, nic_info = NULL;
VARIANT ip_addresses;
char *caption = NULL, *mac_address = NULL;
string ret = "";
try {
pandoraLog ("0");
dhCheck (dhGetObject (getWmiStr (L"."), NULL, &wmi_svc));
dhCheck (dhGetValue (L"%o", &nic_info, wmi_svc,
L".ExecQuery(%S)",
L"SELECT IPAddress FROM Win32_NetworkAdapterConfiguration WHERE IPEnabled = True"));
FOR_EACH (nic_info_item, nic_info, NULL) {
dhGetValue (L"%v", &ip_addresses, nic_info_item,
L".IPAddress");
if (&ip_addresses != NULL)
{
ret = getIPs(&ip_addresses);
if(ret != "0.0.0.0") {
break;
}
}
} NEXT_THROW (nic_info_item);
} catch (string errstr) {
pandoraLog ("runWMIQuery error. %s", errstr.c_str ());
}
return ret;
}

View File

@ -52,6 +52,7 @@ namespace Pandora_Wmi {
string getOSVersion ();
string getOSBuild ();
string getSystemName ();
string getSystemAddress ();
bool runProgram (string command, DWORD flags = 0);
bool startService (string service_name);
bool stopService (string service_name);