check_nwstat.c 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920
  1. /******************************************************************************
  2. *
  3. * Program: NetWare statistics plugin for Nagios
  4. * License: GPL
  5. *
  6. * License Information:
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  21. *
  22. * $Id$
  23. *
  24. *****************************************************************************/
  25. const char *progname = "check_nwstat";
  26. #define REVISION "$Revision$"
  27. #define COPYRIGHT "Copyright (c) 1999-2001 Ethan Galstad"
  28. #define SUMMARY "\
  29. This plugin attempts to contact the MRTGEXT NLM running on a Novell server\n\
  30. to gather the requested system information.\n"
  31. #define OPTIONS "\
  32. -H host [-v variable] [-w warning] [-c critical]\n\
  33. [-p port] [-t timeout]"
  34. #define LONGOPTIONS "\
  35. -H, --hostname=HOST\n\
  36. Name of the host to check\n\
  37. -v, --variable=STRING\n\
  38. Variable to check. Valid variables include:\n\
  39. LOAD1 = 1 minute average CPU load\n\
  40. LOAD5 = 5 minute average CPU load\n\
  41. LOAD15 = 15 minute average CPU load\n\
  42. CONNS = number of currently licensed connections\n\
  43. VPF<vol> = percent free space on volume <vol>\n\
  44. VKF<vol> = KB of free space on volume <vol>\n\
  45. LTCH = percent long term cache hits\n\
  46. CBUFF = current number of cache buffers\n\
  47. CDBUFF = current number of dirty cache buffers\n\
  48. LRUM = LRU sitting time in minutes\n\
  49. DSDB = check to see if DS Database is open\n\
  50. DSVER = NDS version\n\
  51. LOGINS = check to see if logins are enabled\n\
  52. UPRB = used packet receive buffers\n\
  53. PUPRB = percent (of max) used packet receive buffers\n\
  54. SAPENTRIES = number of entries in the SAP table\n\
  55. SAPENTRIES<n> = number of entries in the SAP table for SAP type <n>\n\
  56. OFILES = number of open files\n\
  57. VPP<vol> = percent purgeable space on volume <vol>\n\
  58. VKP<vol> = KB of purgeable space on volume <vol>\n\
  59. VPNP<vol> = percent not yet purgeable space on volume <vol>\n\
  60. VKNP<vol> = KB of not yet purgeable space on volume <vol>\n\
  61. ABENDS = number of abended threads (NW 5.x only)\n\
  62. CSPROCS = number of current service processes (NW 5.x only)\n\
  63. TSYNC = timesync status \n\
  64. LRUS = LRU sitting time in seconds\n\
  65. DCB = dirty cache buffers as a percentage of the total\n\
  66. TCB = dirty cache buffers as a percentage of the original\n\
  67. UPTIME = server uptime\n\
  68. -w, --warning=INTEGER\n\
  69. Threshold which will result in a warning status\n\
  70. -c, --critical=INTEGER\n\
  71. Threshold which will result in a critical status\n\
  72. -p, --port=INTEGER\n\
  73. Optional port number (default: %d)\n\
  74. -t, --timeout=INTEGER\n\
  75. Seconds before connection attempt times out (default: %d)\n\
  76. -o, --osversion\n\
  77. Include server version string in results\n\
  78. -h, --help\n\
  79. Print this help screen\n\
  80. -V, --version\n\
  81. Print version information\n"
  82. #define DESCRIPTION "\
  83. Notes:\n\
  84. - This plugin requres that the MRTGEXT.NLM file from James Drews' MRTG\n\
  85. extension for NetWare be loaded on the Novell servers you wish to check.\n\
  86. (available from http://www.engr.wisc.edu/~drews/mrtg/)\n\
  87. - Values for critical thresholds should be lower than warning thresholds\n\
  88. when the following variables are checked: VPF, VKF, LTCH, CBUFF, DCB, \n\
  89. TCB, LRUS and LRUM.\n"
  90. #include "config.h"
  91. #include "common.h"
  92. #include "netutils.h"
  93. #include "utils.h"
  94. #define CHECK_NONE 0
  95. #define CHECK_LOAD1 1 /* check 1 minute CPU load */
  96. #define CHECK_LOAD5 2 /* check 5 minute CPU load */
  97. #define CHECK_LOAD15 3 /* check 15 minute CPU load */
  98. #define CHECK_CONNS 4 /* check number of connections */
  99. #define CHECK_VPF 5 /* check % free space on volume */
  100. #define CHECK_VKF 6 /* check KB free space on volume */
  101. #define CHECK_LTCH 7 /* check long-term cache hit percentage */
  102. #define CHECK_CBUFF 8 /* check total cache buffers */
  103. #define CHECK_CDBUFF 9 /* check dirty cache buffers */
  104. #define CHECK_LRUM 10 /* check LRU sitting time in minutes */
  105. #define CHECK_DSDB 11 /* check to see if DS Database is open */
  106. #define CHECK_LOGINS 12 /* check to see if logins are enabled */
  107. #define CHECK_PUPRB 13 /* check % of used packet receive buffers */
  108. #define CHECK_UPRB 14 /* check used packet receive buffers */
  109. #define CHECK_SAPENTRIES 15 /* check SAP entries */
  110. #define CHECK_OFILES 16 /* check number of open files */
  111. #define CHECK_VKP 17 /* check KB purgeable space on volume */
  112. #define CHECK_VPP 18 /* check % purgeable space on volume */
  113. #define CHECK_VKNP 19 /* check KB not yet purgeable space on volume */
  114. #define CHECK_VPNP 20 /* check % not yet purgeable space on volume */
  115. #define CHECK_ABENDS 21 /* check abended thread count */
  116. #define CHECK_CSPROCS 22 /* check number of current service processes */
  117. #define CHECK_TSYNC 23 /* check timesync status 0=no 1=yes in sync to the network */
  118. #define CHECK_LRUS 24 /* check LRU sitting time in seconds */
  119. #define CHECK_DCB 25 /* check dirty cache buffers as a percentage of the total */
  120. #define CHECK_TCB 26 /* check total cache buffers as a percentage of the original */
  121. #define CHECK_DSVER 27 /* check NDS version */
  122. #define CHECK_UPTIME 28 /* check server uptime */
  123. #define PORT 9999
  124. char *server_address=NULL;
  125. char *volume_name=NULL;
  126. int server_port=PORT;
  127. unsigned long warning_value=0L;
  128. unsigned long critical_value=0L;
  129. int check_warning_value=FALSE;
  130. int check_critical_value=FALSE;
  131. int check_netware_version=FALSE;
  132. unsigned long vars_to_check=CHECK_NONE;
  133. int sap_number=-1;
  134. int process_arguments(int, char **);
  135. void print_usage(void);
  136. void print_help(void);
  137. int main(int argc, char **argv){
  138. int result;
  139. char *send_buffer=NULL;
  140. char recv_buffer[MAX_INPUT_BUFFER];
  141. char *output_message=NULL;
  142. char *temp_buffer=NULL;
  143. char *netware_version=NULL;
  144. int total_cache_buffers=0;
  145. int dirty_cache_buffers=0;
  146. int time_sync_status=0;
  147. int open_files=0;
  148. int abended_threads=0;
  149. int max_service_processes=0;
  150. int current_service_processes=0;
  151. unsigned long free_disk_space=0L;
  152. unsigned long total_disk_space=0L;
  153. unsigned long purgeable_disk_space=0L;
  154. unsigned long non_purgeable_disk_space=0L;
  155. int percent_free_space=0;
  156. int percent_purgeable_space=0;
  157. int percent_non_purgeable_space=0;
  158. unsigned long current_connections=0L;
  159. unsigned long utilization=0L;
  160. int cache_hits=0;
  161. unsigned long cache_buffers=0L;
  162. unsigned long lru_time=0L;
  163. char uptime[MAX_INPUT_BUFFER];
  164. int max_packet_receive_buffers=0;
  165. int used_packet_receive_buffers=0;
  166. unsigned long percent_used_packet_receive_buffers=0L;
  167. int sap_entries=0;
  168. if(process_arguments(argc,argv)==ERROR)
  169. usage("Could not parse arguments\n");
  170. /* initialize alarm signal handling */
  171. signal(SIGALRM,socket_timeout_alarm_handler);
  172. /* set socket timeout */
  173. alarm(socket_timeout);
  174. /* get OS version string */
  175. if (check_netware_version==TRUE) {
  176. send_buffer = strscpy(send_buffer,"S19\r\n");
  177. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  178. if(result!=STATE_OK)
  179. return result;
  180. if(!strcmp(recv_buffer,"-1\n"))
  181. asprintf(&netware_version,"");
  182. else {
  183. recv_buffer[strlen(recv_buffer)-1]=0;
  184. asprintf(&netware_version,"NetWare %s: ",recv_buffer);
  185. }
  186. } else
  187. asprintf(&netware_version,"");
  188. /* check CPU load */
  189. if (vars_to_check==CHECK_LOAD1 || vars_to_check==CHECK_LOAD5 || vars_to_check==CHECK_LOAD15) {
  190. switch(vars_to_check){
  191. case CHECK_LOAD1:
  192. temp_buffer = strscpy(temp_buffer,"1");
  193. break;
  194. case CHECK_LOAD5:
  195. temp_buffer = strscpy(temp_buffer,"5");
  196. break;
  197. default:
  198. temp_buffer = strscpy(temp_buffer,"15");
  199. break;
  200. }
  201. asprintf(&send_buffer,"UTIL%s\r\n",temp_buffer);
  202. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  203. if(result!=STATE_OK)
  204. return result;
  205. utilization=strtoul(recv_buffer,NULL,10);
  206. send_buffer = strscpy(send_buffer,"UPTIME\r\n");
  207. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  208. if(result!=STATE_OK)
  209. return result;
  210. recv_buffer[strlen(recv_buffer)-1]=0;
  211. sprintf(uptime,"Up %s,",recv_buffer);
  212. if(check_critical_value==TRUE && utilization >= critical_value)
  213. result=STATE_CRITICAL;
  214. else if(check_warning_value==TRUE && utilization >= warning_value)
  215. result=STATE_WARNING;
  216. asprintf(&output_message,"Load %s - %s %s-min load average = %lu%%",(result==STATE_OK)?"ok":"problem",uptime,temp_buffer,utilization);
  217. /* check number of user connections */
  218. } else if (vars_to_check==CHECK_CONNS) {
  219. send_buffer = strscpy(send_buffer,"CONNECT\r\n");
  220. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  221. if(result!=STATE_OK)
  222. return result;
  223. current_connections=strtoul(recv_buffer,NULL,10);
  224. if(check_critical_value==TRUE && current_connections >= critical_value)
  225. result=STATE_CRITICAL;
  226. else if(check_warning_value==TRUE && current_connections >= warning_value)
  227. result=STATE_WARNING;
  228. asprintf(&output_message,"Conns %s - %lu current connections",(result==STATE_OK)?"ok":"problem",current_connections);
  229. /* check % long term cache hits */
  230. } else if (vars_to_check==CHECK_LTCH) {
  231. send_buffer = strscpy(send_buffer,"S1\r\n");
  232. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  233. if(result!=STATE_OK)
  234. return result;
  235. cache_hits=atoi(recv_buffer);
  236. if(check_critical_value==TRUE && cache_hits <= critical_value)
  237. result=STATE_CRITICAL;
  238. else if(check_warning_value==TRUE && cache_hits <= warning_value)
  239. result=STATE_WARNING;
  240. asprintf(&output_message,"Long term cache hits = %d%%",cache_hits);
  241. /* check cache buffers */
  242. } else if (vars_to_check==CHECK_CBUFF) {
  243. send_buffer = strscpy(send_buffer,"S2\r\n");
  244. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  245. if(result!=STATE_OK)
  246. return result;
  247. cache_buffers=strtoul(recv_buffer,NULL,10);
  248. if(check_critical_value==TRUE && cache_buffers <= critical_value)
  249. result=STATE_CRITICAL;
  250. else if(check_warning_value==TRUE && cache_buffers <= warning_value)
  251. result=STATE_WARNING;
  252. asprintf(&output_message,"Total cache buffers = %lu",cache_buffers);
  253. /* check dirty cache buffers */
  254. } else if (vars_to_check==CHECK_CDBUFF) {
  255. send_buffer = strscpy(send_buffer,"S3\r\n");
  256. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  257. if(result!=STATE_OK)
  258. return result;
  259. cache_buffers=strtoul(recv_buffer,NULL,10);
  260. if(check_critical_value==TRUE && cache_buffers >= critical_value)
  261. result=STATE_CRITICAL;
  262. else if(check_warning_value==TRUE && cache_buffers >= warning_value)
  263. result=STATE_WARNING;
  264. asprintf(&output_message,"Dirty cache buffers = %lu",cache_buffers);
  265. /* check LRU sitting time in minutes */
  266. } else if (vars_to_check==CHECK_LRUM) {
  267. send_buffer = strscpy(send_buffer,"S5\r\n");
  268. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  269. if(result!=STATE_OK)
  270. return result;
  271. lru_time=strtoul(recv_buffer,NULL,10);
  272. if(check_critical_value==TRUE && lru_time <= critical_value)
  273. result=STATE_CRITICAL;
  274. else if(check_warning_value==TRUE && lru_time <= warning_value)
  275. result=STATE_WARNING;
  276. asprintf(&output_message,"LRU sitting time = %lu minutes",lru_time);
  277. /* check KB free space on volume */
  278. } else if (vars_to_check==CHECK_VKF) {
  279. asprintf(&send_buffer,"VKF%s\r\n",volume_name);
  280. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  281. if(result!=STATE_OK)
  282. return result;
  283. if (!strcmp(recv_buffer,"-1\n")) {
  284. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  285. result=STATE_CRITICAL;
  286. } else {
  287. free_disk_space=strtoul(recv_buffer,NULL,10);
  288. if(check_critical_value==TRUE && free_disk_space <= critical_value)
  289. result=STATE_CRITICAL;
  290. else if(check_warning_value==TRUE && free_disk_space <= warning_value)
  291. result=STATE_WARNING;
  292. asprintf(&output_message,"%s%lu KB free on volume %s",(result==STATE_OK)?"":"Only ",free_disk_space,volume_name);
  293. }
  294. /* check % free space on volume */
  295. } else if (vars_to_check==CHECK_VPF) {
  296. asprintf(&send_buffer,"VKF%s\r\n",volume_name);
  297. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  298. if(result!=STATE_OK)
  299. return result;
  300. if(!strcmp(recv_buffer,"-1\n")){
  301. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  302. result=STATE_CRITICAL;
  303. } else {
  304. free_disk_space=strtoul(recv_buffer,NULL,10);
  305. asprintf(&send_buffer,"VKS%s\r\n",volume_name);
  306. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  307. if(result!=STATE_OK)
  308. return result;
  309. total_disk_space=strtoul(recv_buffer,NULL,10);
  310. percent_free_space=(int)(((double)free_disk_space/(double)total_disk_space)*100.0);
  311. if(check_critical_value==TRUE && percent_free_space <= critical_value)
  312. result=STATE_CRITICAL;
  313. else if(check_warning_value==TRUE && percent_free_space <= warning_value)
  314. result=STATE_WARNING;
  315. free_disk_space/=1024;
  316. asprintf(&output_message,"%lu MB (%d%%) free on volume %s",free_disk_space,percent_free_space,volume_name);
  317. }
  318. /* check to see if DS Database is open or closed */
  319. } else if(vars_to_check==CHECK_DSDB) {
  320. send_buffer = strscpy(send_buffer,"S11\r\n");
  321. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  322. if(result!=STATE_OK)
  323. return result;
  324. if(atoi(recv_buffer)==1)
  325. result=STATE_OK;
  326. else
  327. result=STATE_WARNING;
  328. send_buffer = strscpy(send_buffer,"S13\r\n");
  329. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  330. temp_buffer=strtok(recv_buffer,"\r\n");
  331. asprintf(&output_message,"Directory Services Database is %s (DS version %s)",(result==STATE_OK)?"open":"closed",temp_buffer);
  332. /* check to see if logins are enabled */
  333. } else if (vars_to_check==CHECK_LOGINS) {
  334. send_buffer = strscpy(send_buffer,"S12\r\n");
  335. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  336. if(result!=STATE_OK)
  337. return result;
  338. if(atoi(recv_buffer)==1)
  339. result=STATE_OK;
  340. else
  341. result=STATE_WARNING;
  342. asprintf(&output_message,"Logins are %s",(result==STATE_OK)?"enabled":"disabled");
  343. /* check packet receive buffers */
  344. } else if (vars_to_check==CHECK_UPRB || vars_to_check==CHECK_PUPRB) {
  345. asprintf(&send_buffer,"S15\r\n",volume_name);
  346. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  347. if(result!=STATE_OK)
  348. return result;
  349. used_packet_receive_buffers=atoi(recv_buffer);
  350. asprintf(&send_buffer,"S16\r\n",volume_name);
  351. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  352. if(result!=STATE_OK)
  353. return result;
  354. max_packet_receive_buffers=atoi(recv_buffer);
  355. percent_used_packet_receive_buffers=(unsigned long)(((double)used_packet_receive_buffers/(double)max_packet_receive_buffers)*100.0);
  356. if(vars_to_check==CHECK_UPRB){
  357. if(check_critical_value==TRUE && used_packet_receive_buffers >= critical_value)
  358. result=STATE_CRITICAL;
  359. else if(check_warning_value==TRUE && used_packet_receive_buffers >= warning_value)
  360. result=STATE_WARNING;
  361. } else {
  362. if(check_critical_value==TRUE && percent_used_packet_receive_buffers >= critical_value)
  363. result=STATE_CRITICAL;
  364. else if(check_warning_value==TRUE && percent_used_packet_receive_buffers >= warning_value)
  365. result=STATE_WARNING;
  366. }
  367. asprintf(&output_message,"%d of %d (%lu%%) packet receive buffers used",used_packet_receive_buffers,max_packet_receive_buffers,percent_used_packet_receive_buffers);
  368. /* check SAP table entries */
  369. } else if (vars_to_check==CHECK_SAPENTRIES) {
  370. if(sap_number==-1)
  371. asprintf(&send_buffer,"S9\r\n");
  372. else
  373. asprintf(&send_buffer,"S9.%d\r\n",sap_number);
  374. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  375. if(result!=STATE_OK)
  376. return result;
  377. sap_entries=atoi(recv_buffer);
  378. if(check_critical_value==TRUE && sap_entries >= critical_value)
  379. result=STATE_CRITICAL;
  380. else if(check_warning_value==TRUE && sap_entries >= warning_value)
  381. result=STATE_WARNING;
  382. if(sap_number==-1)
  383. asprintf(&output_message,"%d entries in SAP table",sap_entries);
  384. else
  385. asprintf(&output_message,"%d entries in SAP table for SAP type %d",sap_entries,sap_number);
  386. /* check KB purgeable space on volume */
  387. } else if (vars_to_check==CHECK_VKP) {
  388. asprintf(&send_buffer,"VKP%s\r\n",volume_name);
  389. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  390. if(result!=STATE_OK)
  391. return result;
  392. if (!strcmp(recv_buffer,"-1\n")) {
  393. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  394. result=STATE_CRITICAL;
  395. } else {
  396. purgeable_disk_space=strtoul(recv_buffer,NULL,10);
  397. if(check_critical_value==TRUE && purgeable_disk_space >= critical_value)
  398. result=STATE_CRITICAL;
  399. else if(check_warning_value==TRUE && purgeable_disk_space >= warning_value)
  400. result=STATE_WARNING;
  401. asprintf(&output_message,"%s%lu KB purgeable on volume %s",(result==STATE_OK)?"":"Only ",purgeable_disk_space,volume_name);
  402. }
  403. /* check % purgeable space on volume */
  404. } else if (vars_to_check==CHECK_VPP) {
  405. asprintf(&send_buffer,"VKP%s\r\n",volume_name);
  406. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  407. if(result!=STATE_OK)
  408. return result;
  409. if(!strcmp(recv_buffer,"-1\n")){
  410. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  411. result=STATE_CRITICAL;
  412. } else {
  413. purgeable_disk_space=strtoul(recv_buffer,NULL,10);
  414. asprintf(&send_buffer,"VKS%s\r\n",volume_name);
  415. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  416. if(result!=STATE_OK)
  417. return result;
  418. total_disk_space=strtoul(recv_buffer,NULL,10);
  419. percent_purgeable_space=(int)(((double)purgeable_disk_space/(double)total_disk_space)*100.0);
  420. if(check_critical_value==TRUE && percent_purgeable_space >= critical_value)
  421. result=STATE_CRITICAL;
  422. else if(check_warning_value==TRUE && percent_purgeable_space >= warning_value)
  423. result=STATE_WARNING;
  424. purgeable_disk_space/=1024;
  425. asprintf(&output_message,"%lu MB (%d%%) purgeable on volume %s",purgeable_disk_space,percent_purgeable_space,volume_name);
  426. }
  427. /* check KB not yet purgeable space on volume */
  428. } else if (vars_to_check==CHECK_VKNP) {
  429. asprintf(&send_buffer,"VKNP%s\r\n",volume_name);
  430. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  431. if(result!=STATE_OK)
  432. return result;
  433. if (!strcmp(recv_buffer,"-1\n")) {
  434. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  435. result=STATE_CRITICAL;
  436. } else {
  437. non_purgeable_disk_space=strtoul(recv_buffer,NULL,10);
  438. if(check_critical_value==TRUE && non_purgeable_disk_space >= critical_value)
  439. result=STATE_CRITICAL;
  440. else if(check_warning_value==TRUE && non_purgeable_disk_space >= warning_value)
  441. result=STATE_WARNING;
  442. asprintf(&output_message,"%s%lu KB not yet purgeable on volume %s",(result==STATE_OK)?"":"Only ",non_purgeable_disk_space,volume_name);
  443. }
  444. /* check % not yet purgeable space on volume */
  445. } else if (vars_to_check==CHECK_VPNP) {
  446. asprintf(&send_buffer,"VKNP%s\r\n",volume_name);
  447. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  448. if(result!=STATE_OK)
  449. return result;
  450. if(!strcmp(recv_buffer,"-1\n")){
  451. asprintf(&output_message,"Error: Volume '%s' does not exist!",volume_name);
  452. result=STATE_CRITICAL;
  453. } else {
  454. non_purgeable_disk_space=strtoul(recv_buffer,NULL,10);
  455. asprintf(&send_buffer,"VKS%s\r\n",volume_name);
  456. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  457. if(result!=STATE_OK)
  458. return result;
  459. total_disk_space=strtoul(recv_buffer,NULL,10);
  460. percent_non_purgeable_space=(int)(((double)non_purgeable_disk_space/(double)total_disk_space)*100.0);
  461. if(check_critical_value==TRUE && percent_non_purgeable_space >= critical_value)
  462. result=STATE_CRITICAL;
  463. else if(check_warning_value==TRUE && percent_non_purgeable_space >= warning_value)
  464. result=STATE_WARNING;
  465. purgeable_disk_space/=1024;
  466. asprintf(&output_message,"%lu MB (%d%%) not yet purgeable on volume %s",non_purgeable_disk_space,percent_non_purgeable_space,volume_name);
  467. }
  468. /* check # of open files */
  469. } else if (vars_to_check==CHECK_OFILES) {
  470. asprintf(&send_buffer,"S18\r\n");
  471. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  472. if(result!=STATE_OK)
  473. return result;
  474. open_files=atoi(recv_buffer);
  475. if(check_critical_value==TRUE && open_files >= critical_value)
  476. result=STATE_CRITICAL;
  477. else if(check_warning_value==TRUE && open_files >= warning_value)
  478. result=STATE_WARNING;
  479. asprintf(&output_message,"%d open files",open_files);
  480. /* check # of abended threads (Netware 5.x only) */
  481. } else if (vars_to_check==CHECK_ABENDS) {
  482. asprintf(&send_buffer,"S17\r\n");
  483. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  484. if(result!=STATE_OK)
  485. return result;
  486. abended_threads=atoi(recv_buffer);
  487. if(check_critical_value==TRUE && abended_threads >= critical_value)
  488. result=STATE_CRITICAL;
  489. else if(check_warning_value==TRUE && abended_threads >= warning_value)
  490. result=STATE_WARNING;
  491. asprintf(&output_message,"%d abended threads",abended_threads);
  492. /* check # of current service processes (Netware 5.x only) */
  493. } else if (vars_to_check==CHECK_CSPROCS) {
  494. asprintf(&send_buffer,"S20\r\n");
  495. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  496. if(result!=STATE_OK)
  497. return result;
  498. max_service_processes=atoi(recv_buffer);
  499. asprintf(&send_buffer,"S21\r\n");
  500. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  501. if(result!=STATE_OK)
  502. return result;
  503. current_service_processes=atoi(recv_buffer);
  504. if(check_critical_value==TRUE && current_service_processes >= critical_value)
  505. result=STATE_CRITICAL;
  506. else if(check_warning_value==TRUE && current_service_processes >= warning_value)
  507. result=STATE_WARNING;
  508. asprintf(&output_message,"%d current service processes (%d max)",current_service_processes,max_service_processes);
  509. /* check # Timesync Status */
  510. } else if (vars_to_check==CHECK_TSYNC) {
  511. asprintf(&send_buffer,"S22\r\n");
  512. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  513. if(result!=STATE_OK)
  514. return result;
  515. time_sync_status=atoi(recv_buffer);
  516. if(time_sync_status==0) {
  517. result=STATE_CRITICAL;
  518. asprintf(&output_message,"Critical: Time not in sync with network!");
  519. }
  520. else {
  521. asprintf(&output_message,"OK! Time in sync with network!");
  522. }
  523. /* check LRU sitting time in secondss */
  524. } else if (vars_to_check==CHECK_LRUS) {
  525. send_buffer = strscpy(send_buffer,"S4\r\n");
  526. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  527. if(result!=STATE_OK)
  528. return result;
  529. lru_time=strtoul(recv_buffer,NULL,10);
  530. if(check_critical_value==TRUE && lru_time <= critical_value)
  531. result=STATE_CRITICAL;
  532. else if(check_warning_value==TRUE && lru_time <= warning_value)
  533. result=STATE_WARNING;
  534. asprintf(&output_message,"LRU sitting time = %lu seconds",lru_time);
  535. /* check % dirty cache buffers as a percentage of the total*/
  536. } else if (vars_to_check==CHECK_DCB) {
  537. send_buffer = strscpy(send_buffer,"S6\r\n");
  538. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  539. if(result!=STATE_OK)
  540. return result;
  541. dirty_cache_buffers=atoi(recv_buffer);
  542. if(check_critical_value==TRUE && dirty_cache_buffers <= critical_value)
  543. result=STATE_CRITICAL;
  544. else if(check_warning_value==TRUE && dirty_cache_buffers <= warning_value)
  545. result=STATE_WARNING;
  546. asprintf(&output_message,"dirty cache buffers = %d%% of the total",dirty_cache_buffers);
  547. /* check % total cache buffers as a percentage of the original*/
  548. } else if (vars_to_check==CHECK_TCB) {
  549. send_buffer = strscpy(send_buffer,"S7\r\n");
  550. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  551. if(result!=STATE_OK)
  552. return result;
  553. total_cache_buffers=atoi(recv_buffer);
  554. if(check_critical_value==TRUE && total_cache_buffers <= critical_value)
  555. result=STATE_CRITICAL;
  556. else if(check_warning_value==TRUE && total_cache_buffers <= warning_value)
  557. result=STATE_WARNING;
  558. asprintf(&output_message,"total cache buffers = %d%% of the original",total_cache_buffers);
  559. } else if (vars_to_check==CHECK_DSVER) {
  560. asprintf(&send_buffer,"S13\r\n");
  561. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  562. if(result!=STATE_OK)
  563. return result;
  564. recv_buffer[strlen(recv_buffer)-1]=0;
  565. asprintf(&output_message,"NDS Version %s",recv_buffer);
  566. } else if (vars_to_check==CHECK_UPTIME) {
  567. asprintf(&send_buffer,"UPTIME\r\n");
  568. result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer));
  569. if(result!=STATE_OK)
  570. return result;
  571. recv_buffer[strlen(recv_buffer)-1]=0;
  572. asprintf(&output_message,"Up %s",recv_buffer);
  573. } else {
  574. output_message = strscpy(output_message,"Nothing to check!\n");
  575. result=STATE_UNKNOWN;
  576. }
  577. /* reset timeout */
  578. alarm(0);
  579. printf("%s%s\n",netware_version,output_message);
  580. return result;
  581. }
  582. /* process command-line arguments */
  583. int process_arguments(int argc, char **argv){
  584. int c;
  585. int option_index = 0;
  586. static struct option long_options[] =
  587. {
  588. {"port", required_argument,0,'p'},
  589. {"timeout", required_argument,0,'t'},
  590. {"critical", required_argument,0,'c'},
  591. {"warning", required_argument,0,'w'},
  592. {"variable", required_argument,0,'v'},
  593. {"hostname", required_argument,0,'H'},
  594. {"osversion",no_argument, 0,'o'},
  595. {"version", no_argument, 0,'V'},
  596. {"help", no_argument, 0,'h'},
  597. {0,0,0,0}
  598. };
  599. /* no options were supplied */
  600. if(argc<2) return ERROR;
  601. /* backwards compatibility */
  602. if (! is_option(argv[1])) {
  603. server_address=argv[1];
  604. argv[1]=argv[0];
  605. argv=&argv[1];
  606. argc--;
  607. }
  608. for (c=1;c<argc;c++) {
  609. if(strcmp("-to",argv[c])==0)
  610. strcpy(argv[c],"-t");
  611. else if (strcmp("-wv",argv[c])==0)
  612. strcpy(argv[c],"-w");
  613. else if (strcmp("-cv",argv[c])==0)
  614. strcpy(argv[c],"-c");
  615. }
  616. while (1){
  617. c = getopt_long(argc,argv,"+hoVH:t:c:w:p:v:",long_options,&option_index);
  618. if (c==-1||c==EOF||c==1)
  619. break;
  620. switch (c)
  621. {
  622. case '?': /* print short usage statement if args not parsable */
  623. printf ("%s: Unknown argument: %s\n\n", progname, optarg);
  624. print_usage();
  625. exit(STATE_UNKNOWN);
  626. case 'h': /* help */
  627. print_help();
  628. exit(STATE_OK);
  629. case 'V': /* version */
  630. print_revision(progname,"$Revision$");
  631. exit(STATE_OK);
  632. case 'H': /* hostname */
  633. server_address=optarg;
  634. break;
  635. case 'o': /* display nos version */
  636. check_netware_version=TRUE;
  637. break;
  638. case 'p': /* port */
  639. if (is_intnonneg(optarg))
  640. server_port=atoi(optarg);
  641. else
  642. terminate(STATE_UNKNOWN,"Server port an integer (seconds)\nType '%s -h' for additional help\n",progname);
  643. break;
  644. case 'v':
  645. if(strlen(optarg)<3)
  646. return ERROR;
  647. if(!strcmp(optarg,"LOAD1"))
  648. vars_to_check=CHECK_LOAD1;
  649. else if(!strcmp(optarg,"LOAD5"))
  650. vars_to_check=CHECK_LOAD5;
  651. else if(!strcmp(optarg,"LOAD15"))
  652. vars_to_check=CHECK_LOAD15;
  653. else if(!strcmp(optarg,"CONNS"))
  654. vars_to_check=CHECK_CONNS;
  655. else if(!strcmp(optarg,"LTCH"))
  656. vars_to_check=CHECK_LTCH;
  657. else if(!strcmp(optarg,"DCB"))
  658. vars_to_check=CHECK_DCB;
  659. else if(!strcmp(optarg,"TCB"))
  660. vars_to_check=CHECK_TCB;
  661. else if(!strcmp(optarg,"CBUFF"))
  662. vars_to_check=CHECK_CBUFF;
  663. else if(!strcmp(optarg,"CDBUFF"))
  664. vars_to_check=CHECK_CDBUFF;
  665. else if(!strcmp(optarg,"LRUM"))
  666. vars_to_check=CHECK_LRUM;
  667. else if(!strcmp(optarg,"LRUS"))
  668. vars_to_check=CHECK_LRUS;
  669. else if(strncmp(optarg,"VPF",3)==0){
  670. vars_to_check=CHECK_VPF;
  671. volume_name = strscpy(volume_name,optarg+3);
  672. if(!strcmp(volume_name,""))
  673. volume_name = strscpy(volume_name,"SYS");
  674. }
  675. else if(strncmp(optarg,"VKF",3)==0){
  676. vars_to_check=CHECK_VKF;
  677. volume_name = strscpy(volume_name,optarg+3);
  678. if(!strcmp(volume_name,""))
  679. volume_name = strscpy(volume_name,"SYS");
  680. }
  681. else if(!strcmp(optarg,"DSDB"))
  682. vars_to_check=CHECK_DSDB;
  683. else if(!strcmp(optarg,"LOGINS"))
  684. vars_to_check=CHECK_LOGINS;
  685. else if(!strcmp(optarg,"UPRB"))
  686. vars_to_check=CHECK_UPRB;
  687. else if(!strcmp(optarg,"PUPRB"))
  688. vars_to_check=CHECK_PUPRB;
  689. else if(!strncmp(optarg,"SAPENTRIES",10)){
  690. vars_to_check=CHECK_SAPENTRIES;
  691. if(strlen(optarg)>10)
  692. sap_number=atoi(optarg+10);
  693. else
  694. sap_number=-1;
  695. }
  696. else if(!strcmp(optarg,"OFILES"))
  697. vars_to_check=CHECK_OFILES;
  698. else if(strncmp(optarg,"VKP",3)==0){
  699. vars_to_check=CHECK_VKP;
  700. volume_name = strscpy(volume_name,optarg+3);
  701. if(!strcmp(volume_name,""))
  702. volume_name = strscpy(volume_name,"SYS");
  703. }
  704. else if(strncmp(optarg,"VPP",3)==0){
  705. vars_to_check=CHECK_VPP;
  706. volume_name = strscpy(volume_name,optarg+3);
  707. if(!strcmp(volume_name,""))
  708. volume_name = strscpy(volume_name,"SYS");
  709. }
  710. else if(strncmp(optarg,"VKNP",4)==0){
  711. vars_to_check=CHECK_VKNP;
  712. volume_name = strscpy(volume_name,optarg+4);
  713. if(!strcmp(volume_name,""))
  714. volume_name = strscpy(volume_name,"SYS");
  715. }
  716. else if(strncmp(optarg,"VPNP",4)==0){
  717. vars_to_check=CHECK_VPNP;
  718. volume_name = strscpy(volume_name,optarg+4);
  719. if(!strcmp(volume_name,""))
  720. volume_name = strscpy(volume_name,"SYS");
  721. }
  722. else if(!strcmp(optarg,"ABENDS"))
  723. vars_to_check=CHECK_ABENDS;
  724. else if(!strcmp(optarg,"CSPROCS"))
  725. vars_to_check=CHECK_CSPROCS;
  726. else if(!strcmp(optarg,"TSYNC"))
  727. vars_to_check=CHECK_TSYNC;
  728. else if(!strcmp(optarg,"DSVER"))
  729. vars_to_check=CHECK_DSVER;
  730. else if(!strcmp(optarg,"UPTIME"))
  731. vars_to_check=CHECK_UPTIME;
  732. else
  733. return ERROR;
  734. break;
  735. case 'w': /* warning threshold */
  736. warning_value=strtoul(optarg,NULL,10);
  737. check_warning_value=TRUE;
  738. break;
  739. case 'c': /* critical threshold */
  740. critical_value=strtoul(optarg,NULL,10);
  741. check_critical_value=TRUE;
  742. break;
  743. case 't': /* timeout */
  744. socket_timeout=atoi(optarg);
  745. if(socket_timeout<=0)
  746. return ERROR;
  747. }
  748. }
  749. return OK;
  750. }
  751. void print_usage(void)
  752. {
  753. printf
  754. ("Usage:\n"
  755. " %s %s\n"
  756. " %s (-h | --help) for detailed help\n"
  757. " %s (-V | --version) for version information\n",
  758. progname, OPTIONS, progname, progname);
  759. }
  760. void print_help(void)
  761. {
  762. print_revision (progname, REVISION);
  763. printf ("%s\n\n%s\n", COPYRIGHT, SUMMARY);
  764. print_usage();
  765. printf
  766. ("\nOptions:\n" LONGOPTIONS "\n" DESCRIPTION "\n",
  767. PORT, DEFAULT_SOCKET_TIMEOUT);
  768. support ();
  769. }