Changelog 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
  1. **************
  2. NRPE Changelog
  3. **************
  4. 3.0 = xx/xx/xxxx
  5. -----------------
  6. SECURITY
  7. - Fix for CVE-2014-2913
  8. - Added function to clean the environment before forking. (John Frickson)
  9. ENHANCEMENTS
  10. - Added support for optional config file to check_nrpe. With the new SSL
  11. parameters, the line was getting long. The config file is specified with
  12. --config-file=<path> or -f <path> parameters. The config file must look
  13. like command line options, but the options can be on separate lines. It
  14. MUST NOT include --config-file (-f), --command (-c) or --args (-a). If any
  15. options are in both the config file and on the command line, the command line
  16. options are used.
  17. - make can now add users and groups using "make install-groups-users" (John Frickson)
  18. - Added "nrpe-uninstall" script to the same directory nrpe get installed to (John Frickson)
  19. - Updated code so configure && make will work on AIX, HP-UX, Solaris, OS X.
  20. There should be no errors or warnings. Let me know if any errors or
  21. warning appear (John Frickson)
  22. - Added command-line option to prevent forking, since some of the init
  23. replacements (such as systemd, etc.) don't want daemons to fork (John Frickson)
  24. - Added autoconf macros and additional files to better support multi-platform
  25. config and compile. The default will still set up to install to
  26. /usr/local/nagios but I added a new configure option:
  27. '--enable-install-method=<method>'. If <method> is 'opt', everything will
  28. install to '/opt/nagios'. If <method> is 'os', installation will be to O/S-
  29. and distribution-specific locations, such as /usr/sbin, /usr/lib/nagios,
  30. /etc/nagios, and so on.
  31. - Added additional init and inetd config files to support more systems,
  32. including SuSE, Debian, Slackware, Gentoo, *BSD, AIX, HP-UX, Solaris, OS X.
  33. - Added listen_queue_size as configuration option (Vadim Antipov, Kaspersky Lab)
  34. - Reworked SSL/TLS. See the README.SSL.md file for full info. (John Frickson)
  35. - Added support for version 3 variable sized packets up to 64KB. nrpe will
  36. accept either version from check_nrpe. check_nrpe will try to send a
  37. version 3 packet first, and fall back to version 2. check_nrpe can be forced
  38. to only send version 2 packets if the switch `-2` is used. (John Frickson)
  39. FIXES
  40. - Fixed configure to check more places for SSL headers/libs. (John Frickson)
  41. - Added ifdefs for complete_SSL_shutdown to compile without SSL. (Matthew L. Daniel)
  42. - Renamed configure.in to configure.ac and added check for sigaction (John Frickson)
  43. - Replaced all instances of signal() with sigaction() + blocking (John Frickson)
  44. - check_nrpe does not parse passed arguments correctly (John Frickson)
  45. - NRPE should not start if cannot write pid file (John Frickson)
  46. - Fixed out-of-bounds error (return code 255) for some failures (John Frickson)
  47. - Connection Timeout and Connection Refused messages need a new line (Andrew Widdersheim)
  48. - allowed_hosts doesn't work, if one of the hostnames can't be resolved by dns (John Frickson)
  49. - allowed_hosts doesn't work with a hostname resolving to an IPv6 address (John Frickson)
  50. - Return UNKNOWN when issues occur (Andrew Widdersheim)
  51. - NRPE returns OK if check can't be executed (Andrew Widdersheim)
  52. - nrpe 2.15 [regression in Added SRC support on AIX - 2.14] (frphoebus)
  53. - compile nrpe - Solaris 9 doesn't have isblank() (lilo, John Frickson)
  54. - sample configuration for check_load has crazy sample load avg (ernestoongaro)
  55. 2.15 - 09/06/2013
  56. -----------------
  57. - Now compiles on HP-UX (Grant Byers)
  58. - Added support for IPv6 (Leo Baltus, Eric Stanley)
  59. 2.14 - 12/21/2012
  60. -----------------
  61. - Added configure option to allow bash command substitutions, disabled by default [bug #400] (Eric Stanley)
  62. - Patched to shutdown SSL connection completely (Jari Takkala)
  63. - Added SRC support on AIX (Thierry Bertaud)
  64. - Updated RPM SPEC file to support creating RPMs on AIX (Eric Stanley)
  65. - Updated logging to support compiling on AIX (Eric Stanley)
  66. 2.13 - 11/11/2011
  67. -----------------
  68. - Applied Kaspersky Labs supplied patch for extending allowed_hosts (Konstantin Malov)
  69. - Fixed bug in allowed_hosts parsing (Eric Stanley)
  70. - Updated to support compiling on Solaris 10 (thanks to Kevin Pendleton)
  71. 2.12 - 03/10/2008
  72. -----------------
  73. - Fix for unterminated multiline plugin (garbage) output (Krzysztof Oledzki)
  74. 2.11 - 12/26/2007
  75. -----------------
  76. - Added lib64 library paths to configure script for 64-bit systems (John Maag)
  77. - Added --with-ssl-lib configure script option
  78. - Added --with-log-facility option to control syslog logging (Ryan Ordway and Brian Seklecki)
  79. 2.10 - 10/19/2007
  80. -----------------
  81. - Moved PDF docs to docs/ subdirectory, added OpenOffice source document
  82. - A critical result is now returned for child processed that die due to a signal (Klas Lindfors)
  83. 2.9 - 08/13/2007
  84. ----------------
  85. - Fixed bug with --with-nrpe-group configure script option (Graham Collinson)
  86. - Fixed bug with check_disk thresholds in sample config file (Patric Wust)
  87. - Added NRPE_PROGRAMVERSION and NRPE_MULTILINESUPPORT environment variables
  88. for scripts that need to detect NRPE version and capabilities (Gerhard Lausser)
  89. - Added asprintf() support for systems that are missing it (Samba team)
  90. 2.8.1 - 05/10/2007
  91. -----------------
  92. - Fixed configure script error with user-specified NRPE group
  93. 2.8 - 05/08/2007
  94. ---------------
  95. - Added support for multiline plugin output (limited to 1KB at the moment) (Matthias Flacke)
  96. 2.8b1 - 03/14/2007
  97. -----------------
  98. - Changes to sample config files
  99. - Added ';' as an additional prohibited metachar for command arguments
  100. - Updated documentation and added easier installation commands
  101. 2.7.1 - 03/08/2007
  102. ------------------
  103. - Changed C++ style comment to C style to fix compilation errors on AIX (Ryan McGarry)
  104. 2.7 - 02/18/2007
  105. ----------------
  106. - Patches for detection SSL header and library locations (Andrew Boyce-Lewis)
  107. - NRPE daemon will now partially ignore non-fatal configuration file errors and attempt to startup (Andrew Boyce-Lewis)
  108. 2.6 - 12/11/2006
  109. ----------------
  110. - Added -u option to check_nrpe to return UNKNOWN states on socket timeouts (Bjoern Beutel)
  111. - Added connection_timeout variable to NRPE daemon to catch dead client connections (Ton Voon)
  112. - Added graceful timeout to check_nrpe to ensure connection to NRPE daemon is properly closed (Mark Plaksin)
  113. 2.5.2 - 06/30/2006
  114. ------------------
  115. - Fixed incorrect service name in sample xinetd config file
  116. - Added note on how to restart inetd for OpenBSD users (Robert Peaslee)
  117. - Fix for nonblocking accept()s on systems that define EAGAIN differently than EWOULDBLOCK (Gerhard Lausser)
  118. - Fix to (re)allow week random seed (Gerhard Lausser)
  119. 2.5.1 - 04/09/2006
  120. ------------------
  121. - Patch to fix segfault if --no-ssl option is used (Sean Finney/Peter Palfrader)
  122. 2.5 - 04/06/2006
  123. ----------------
  124. - (Re)added allowed_hosts option for systems that don't support TCP wrappers
  125. - Fix for SSL errors under Solaris 8 (Niels Endres)
  126. - Fix for config file directory inclusion on ReiserFS (Gerhard Lausser)
  127. 2.4 - 02/22/2006
  128. ----------------
  129. - Added option to allow week random seed (Gerhard Lausser)
  130. - Added optional command line prefix (Sean Finney)
  131. - Added ability to reload config file with SIGHUP
  132. - Fixed bug with location of dh.h include file
  133. - Fixed bug with disconnect message in debug mode
  134. 2.3 - 01/23/2006
  135. ----------------
  136. - Spec file fixes
  137. - Removed errant PID file debugging code
  138. - Fixed problem with trimming command definitions
  139. 2.2 - 01/22/2006
  140. ----------------
  141. - Spec file fix
  142. - Patch to add Tru64 and IRIX support (Ton Voon)
  143. - Updated config.sub and config.guess
  144. - Fixed bug with config file lines with only whitespace
  145. - Fixed bug with missing getopt() command line option for -V
  146. - Removed sample FreeBSD init script (now maintained by FreeBSD port)
  147. - Added config file option for writing a PID file
  148. 2.1 - 01/19/2004
  149. ----------------
  150. - Replaced host access list with TCP wrapper support
  151. - Removed length restrictions for command names and command lines
  152. - Configure script patch for getopt_long on Solaris
  153. - Bug fixes for accept() on HP-UX 11.0
  154. - Init script for SUSE Linux (Subhendu Ghosh)
  155. - SSL protocol used is now limited to TLSv1
  156. - Any output from plugins after first line is now ignored before
  157. plugin process is closed
  158. 2.0 - 09/08/2003
  159. ----------------
  160. - Added support for passing arguments to command
  161. - NRPE daemon can no longer be run as root user/group
  162. - Added getopt support
  163. - Added 'include' variable to config file to allow inclusion
  164. of external config files
  165. - Added 'include_dir' variable to allow inclusion of external
  166. config files in directories (with recursion)
  167. - Added native SSL support (Derrick Bennett)
  168. - Added my_strsep(), as Solaris doesn't have strsep()
  169. - Added license exemption for use with OpenSSL
  170. 1.8 - 01/16/2003
  171. ----------------
  172. - Daemon now closes stdio/out/err properly (James Peterson)
  173. - Makefile changes (James Peterson)
  174. - Mode command line option bug fix in daemon
  175. - Fixed incorrect command line options in check_nrpe plugin
  176. 1.7 - 01/08/2003
  177. ----------------
  178. - Spec file updates and minor bug fixes (James Peterson)
  179. - Bug fix with default nrpe port definition
  180. - Added sample xinetd config file (nrpe.xinetd)
  181. - Bug fix for command_timeout variable (James Peterson)
  182. 1.6 - 12/30/2002
  183. ----------------
  184. - Updated sample commands to match new plugin argument format
  185. - Added sample init scripts for FreeBSD and Debian (Andrew Ryder)
  186. - Syntax changes (-H option specifies host name in check_nrpe,
  187. -c option specifies config file in nrpe)
  188. - Added command_timeout directive to config file to allow user
  189. to specify timeout for executing plugins
  190. - Added spec file and misc patches for building RPMs (James Peterson)
  191. - Added --with-nrpe-port config directive (James Peterson)
  192. 1.5 - 06/03/2002
  193. ----------------
  194. - Added setuid/setgid option to config file (suggested by Marek Cervenka)
  195. 1.4 - 06/01/2002
  196. ----------------
  197. - Changed STATE_UNKNOWN to value of 3 instead of -1 (old style)
  198. - Minor doc and sample config file changes
  199. 1.3 - 02/21/2002
  200. ----------------
  201. - Name and version change
  202. - Ignore SIGHUP, minor cleanup (Jon Andrews)
  203. 1.2.5 - 12/22/2001
  204. ------------------
  205. - Implemented Beej's sendall() to handle partial send()s
  206. - Added instructions on running under xinetd to README
  207. - Removed some old crud
  208. 1.2.4 - 02/22/2001
  209. ------------------
  210. - I forgot what changes I made. Go figure...
  211. 1.2.3 - 12/21/2000
  212. ------------------
  213. - A bit more documentation on configuring command definitions for the plugin
  214. 1.2.2 - 06/05/2000
  215. ------------------
  216. - Fixed error in docs for running under inetd using TCP wrappers
  217. - Replaced old email address in src/netutils.h with new one
  218. 1.2.1 - 05/07/2000
  219. ------------------
  220. - Removed trapping of SIGCHLD
  221. - Changed wait4() to waitpid() to allow compilation on HP-UX and AIX
  222. 1.2.0 - 04/18/2000
  223. ------------------
  224. - Server forks twice after accepting a client connection, so as to prevent the
  225. creation of zombies
  226. 1.1.5 - 04/07/2000
  227. ------------------
  228. - Fixed a small bug where one debug message was not getting logged properly
  229. 1.1.4 - 03/30/2000
  230. ------------------
  231. - Added option to disable/enable debug messages using the debug option in the
  232. config file
  233. 1.1.3 - 03/11/2000
  234. ------------------
  235. - Changed config file to use an absolute path
  236. - Changed all debug output to use syslog (Rene Klootwijk)
  237. - No convert all data to network order before sending it and convert it back to
  238. host order when receiving it. This makes it possible to mix Solaris and Linux,
  239. e.g. running check_nrpe on Linux and nrpe on Solaris. (Rene Klootwijk)
  240. 1.1.2 - 03/07/2000
  241. ------------------
  242. - Removed unnecessary code in signal handler routine
  243. - Unused signals are no longer trapper
  244. 1.1.1 - 02/28/2000 - RKL
  245. ---------------------------
  246. - Modified syslog code to include string describing the error code.
  247. - Changed hardcoded number in signal handler to its name. This prevented nrpe
  248. to run on Solaris.
  249. - Fixed race condition in accept loop. The result of accept should also be
  250. checked for EINTR.
  251. - Modified recv and send function calls to compile without warnings on Solaris.
  252. - Modified configure.in,configure and Makefile.in to include nsl and socket libs
  253. for Solaris.
  254. - Modified the signal handler to reestablish itself after being called.
  255. 1.1 - 02/24/2000 - Rene Klootwijk <rene@klootwijk.org>
  256. -----------------
  257. - Added ability to bind nrpe to a specific interface by specifying the address
  258. of this interface in the nrpe.cfg file (e.g. server_address=192.168.2.3)
  259. 1.0 - 02/16/2000
  260. ------------------
  261. - Added ability to run as a service under inetd
  262. 1.0b6 - 02/01/2000
  263. ------------------
  264. - Added configure script
  265. - Netutils functions from the NetSaint plugins is now used
  266. - Reset SIGCHLD to default behavior before calling popen() to
  267. prevent race condition with pclose() (Reported by Rene Klootwijk)
  268. - Cleaned up code
  269. 1.0b5 - 01/10/2000
  270. ------------------
  271. - Added init script contributed by Jacob L
  272. - Incorporated syslog code and other patches contributed by Jacob L
  273. 1.0b4 - 11/04/1999
  274. ------------------
  275. - Changed 'allowed_ip' option in configuration file to
  276. 'allowed_hosts' and added support for multiple hosts
  277. - Minor buffer overflow protection fixes
  278. - main() returned STATE_UNKNOWN on successful launch, changed to STATE_OK (jaclu@grm.se)
  279. - Added syslog support (jaclu@grm.se)