check_nwstat.c 27 KB

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