SEARCH
NEW RPMS
DIRECTORIES
ABOUT
FAQ
VARIOUS
BLOG

 
 
Changelog for ruby2.7-rubygem-puma-5-5.6.8-lp156.8.3.x86_64.rpm :

* Mon Jan 29 2024 Dan Čermák - New upstream release 5.6.8, see bundled History.md
* Fri Nov 03 2023 Dan Čermák - 5.6.7: Security Address HTTP request smuggling vulnerabilities with zero-length Content Length header and trailer fields ([GHSA-68xg-gqqm-vgj8](https://github.com/puma/puma/security/advisories/GHSA-68xg-gqqm-vgj8))
* Mon Jan 02 2023 Stephan Kulow - Update to version 5.6.5 (decoupling from main puma) 5.6.5 / 2022-08-23 • Feature
* Puma::ControlCLI - allow refork command to be sent as a request (#2868, [#2866]) • Bugfixes
* NullIO#closed should return false (#2883)
* [jruby] Fix TLS verification hang (#2890, #2729)
* extconf.rb - don\'t use pkg_config(\'openssl\') if \'--with-openssl-dir\' is used (#2885, #2839)
* MiniSSL - detect SSL_CTX_set_dh_auto (#2864, #2863)
* Fix rack.after_reply exceptions breaking connections (#2861, #2856)
* Escape SSL cert and filenames (#2855)
* Fail hard if SSL certs or keys are invalid (#2848)
* Fail hard if SSL certs or keys cannot be read by user (#2847)
* Fix build with Opaque DH in LibreSSL 3.5. (#2838)
* Pre-existing socket file removed when TERM is issued after USR2 (if puma is running in cluster mode) (#2817)
* Fix Puma::StateFile#load incompatibility (#2810) 5.6.4 / 2022-03-30 • Security
* Close several HTTP Request Smuggling exploits (CVE-2022-24790) 5.6.2 / 2022-02-11 • Bugfix/Security
* Response body will always be closed. (GHSA-rmj8-8hhh-gv5h, related to # 2809) 5.6.1 / 2022-01-26 • Bugfixes
* Reverted a commit which appeared to be causing occasional blank header values (#2809) 5.6.0 / 2022-01-25 • Features
* Support localhost integration in ssl_bind (#2764, #2708)
* Allow backlog parameter to be set with ssl_bind DSL (#2780)
* Remove yaml (psych) requirement in StateFile (#2784)
* Allow culling of oldest workers, previously was only youngest (#2773, # 2794)
* Add worker_check_interval configuration option (#2759)
* Always send lowlevel_error response to client (#2731, #2341)
* Support for cert_pem and key_pem with ssl_bind DSL (#2728) • Bugfixes
* Keep thread names under 15 characters, prevents breakage on some OSes ( [#2733])
* Fix two \'old-style-definition\' compile warning (#2807, #2806)
* Log environment correctly using option value (#2799)
* Fix warning from Ruby master (will be 3.2.0) (#2785)
* extconf.rb - fix openssl with old Windows builds (#2757)
* server.rb - rescue handling (Errno::EBADF) for AATTnotify.close (#2745) • Refactor
* server.rb - refactor code using AATToptions[:remote_address] (#2742)
* [jruby] a couple refactorings - avoid copy-ing bytes (#2730) 5.5.2 / 2021-10-12 • Bugfixes
* Allow UTF-8 in HTTP header values 5.5.1 / 2021-10-12 • Feature (added as mistake - we don\'t normally do this on bugfix releases, sorry!)
* Allow setting APP_ENV in preference to RACK_ENV or RAILS_ENV (#2702) • Security
* Do not allow LF as a line ending in a header (CVE-2021-41136) 5.5.0 / 2021-09-19 • Features
* Automatic SSL certificate provisioning for localhost, via localhost gem (#2610, #2257)
* add support for the PROXY protocol (v1 only) (#2654, #2651)
* Add a semantic CLI option for no config file (#2689) • Bugfixes
* More elaborate exception handling - lets some dead pumas die. (#2700, # 2699)
* allow multiple after_worker_fork hooks (#2690)
* Preserve BUNDLE_APP_CONFIG on worker fork (#2688, #2687) • Performance
* Fix performance of server-side SSL connection close. (#2675) 5.4.0 / 2021-07-28 • Features
* Better/expanded names for threadpool threads (#2657)
* Allow pkg_config for OpenSSL (#2648, #1412)
* Add rack_url_scheme to Puma::DSL, allows setting of rack.url_scheme header (#2586, #2569) • Bugfixes
* Binder#parse - allow for symlinked unix path, add create_activated_fds debug ENV (#2643, #2638)
* Fix deprecation warning: minissl.c - Use Random.bytes if available (# 2642)
* Client certificates: set session id context while creating SSLContext ( [#2633])
* Fix deadlock issue in thread pool (#2656) • Refactor
* Replace IO.select with IO#wait_
* when checking a single IO (#2666) 5.3.2 / 2021-05-21 • Bugfixes
* Gracefully handle Rack not accepting CLI options (#2630, #2626)
* Fix sigterm misbehavior (#2629)
* Improvements to keepalive-connection shedding (#2628) 5.3.1 / 2021-05-11 • Security
* Close keepalive connections after the maximum number of fast inlined requests (CVE-2021-29509) (#2625) 5.3.0 / 2021-05-07 • Features
* Add support for Linux\'s abstract sockets (#2564, #2526)
* Add debug to worker timeout and startup (#2559, #2528)
* Print warning when running one-worker cluster (#2565, #2534)
* Don\'t close systemd activated socket on pumactl restart (#2563, #2504) • Bugfixes
* systemd - fix event firing (#2591, #2572)
* Immediately unlink temporary files (#2613)
* Improve parsing of HTTP_HOST header (#2605, #2584)
* Handle fatal error that has no backtrace (#2607, #2552)
* Fix timing out requests too early (#2606, #2574)
* Handle segfault in Ruby 2.6.6 on thread-locals (#2567, #2566)
* Server#closed_socket? - parameter may be a MiniSSL::Socket (#2596)
* Define UNPACK_TCP_STATE_FROM_TCP_INFO in the right place (#2588, #2556)
* request.rb - fix chunked assembly for ascii incompatible encodings, add test (#2585, #2583) • Performance
* Reset peerip only if remote_addr_header is set (#2609)
* Reduce puma_parser struct size (#2590) • Refactor
* Refactor drain on shutdown (#2600)
* Micro optimisations in wait_for_less_busy_worker feature (#2579)
* Lots of test fixes 5.2.2 / 2021-02-22 • Bugfixes
* Add #flush and #sync methods to Puma::NullIO (#2553)
* Restore sync=true on STDOUT and STDERR streams (#2557) 5.2.1 / 2021-02-05 • Bugfixes
* Fix TCP cork/uncork operations to work with ssl clients (#2550)
* Require rack/common_logger explicitly if :verbose is true (#2547)
* MiniSSL::Socket#write - use data.byteslice(wrote..-1) (#2543)
* Set AATTenv[CONTENT_LENGTH] value as string. (#2549) 5.2.0 / 2021-01-27 • Features
* 10x latency improvement for MRI on ssl connections by reducing overhead (#2519)
* Add option to specify the desired IO selector backend for libev (#2522)
* Add ability to set OpenSSL verification flags (MRI only) (#2490)
* Uses flush after writing messages to avoid mutating $stdout and $stderr using sync=true (#2486) • Bugfixes
* MiniSSL - Update dhparam to 2048 bit for use with SSL_CTX_set_tmp_dh (# 2535)
* Change \'Goodbye!\' message to be output after listeners are closed (# 2529)
* Fix ssl bind logging with 0.0.0.0 and localhost (#2533)
* Fix compiler warnings, but skipped warnings related to ragel state machine generated code (#1953)
* Fix phased restart errors related to nio4r gem when using the Puma control server (#2516)
* Add #string method to Puma::NullIO (#2520)
* Fix binding via Rack handler to IPv6 addresses (#2521) • Refactor
* Refactor MiniSSL::Context on MRI, fix MiniSSL::Socket#write (#2519)
* Remove Server#read_body (#2531)
* Fail build if compiling extensions raises warnings on GH Actions, configurable via MAKE_WARNINGS_INTO_ERRORS (#1953) 5.1.1 / 2020-12-10 • Bugfixes
* Fix over eager matching against banned header names (#2510) 5.1.0 / 2020-11-30 • Features
* Phased restart availability is now always logged, even if it is not available.
* Prints the loaded configuration if the environment variable PUMA_LOG_CONFIG is present (#2472)
* Integrate with systemd\'s watchdog and notification features (#2438)
* Adds max_fast_inline as a configuration option for the Server object (# 2406)
* You can now fork workers from worker 0 using SIGURG w/o fork_worker enabled #2449
* Add option to bind to systemd activated sockets (#2362)
* Add compile option to change the QUERY_STRING max length (#2485) • Bugfixes
* Fix JRuby handling in Puma::DSL#ssl_bind (#2489)
* control_cli.rb - all normal output should be to AATTstdout (#2487)
* Catch \'Error in reactor loop escaped: mode not supported for this object: r\' (#2477)
* Ignore Rails\' reaper thread (and any thread marked forksafe) for warning (#2475)
* Ignore illegal (by Rack spec) response header (#2439)
* Close idle connections immediately on shutdown (#2460)
* Fix some instances of phased restart errors related to the json gem (# 2473)
* Remove use of json gem to fix phased restart errors (#2479)
* Fix grouping regexp of ILLEGAL_HEADER_KEY_REGEX (#2495)
* Sun Nov 01 2020 Manuel Schnitzer - updated to version 5.0.4
* Bugfixes
* Pass preloaded application into new workers if available when using `preload_app` ([#2461], [#2454]) [#]# 5.0.3 / 2020-10-26
* Bugfixes
* Add Client#io_ok?, check before Reactor#register ([#2432])
* Fix hang on shutdown in refork ([#2442])
* Fix `Bundler::GemNotFound` errors for `nio4r` gem during phased restarts ([#2427], [#2018])
* Server run thread safety fix ([#2435])
* Fire `on_booted` after server starts ([#2431], [#2212])
* Cleanup daemonization in rc.d script ([#2409])
* Refactor
* Remove accept_nonblock.rb, add test_integration_ssl.rb ([#2448])
* Refactor status.rb - dry it up a bit ([#2450])
* Extract req/resp methods to new request.rb from server.rb ([#2419])
* Refactor Reactor and Client request buffering ([#2279])
* client.rb - remove JRuby specific \'finish\' code ([#2412])
* Consolidate fast_write calls in Server, extract early_hints assembly ([#2405])
* Remove upstart from docs ([#2408])
* Extract worker process into separate class ([#2374])
* Consolidate option handling in Server, Server small refactors, doc changes ([#2389]) [#]# 5.0.2 / 2020-09-28
* Bugfixes
* Reverted API changes to Server. [#]# 5.0.1 / 2020-09-28
* Bugfixes
* Fix LoadError in CentOS 8 ([#2381])
* Better error handling during force shutdown ([#2271])
* Prevent connections from entering Reactor after shutdown begins ([#2377])
* Fix error backtrace debug logging && Do not log request dump if it is not parsed ([#2376])
* Split TCP_CORK and TCP_INFO ([#2372])
* Do not log EOFError when a client connection is closed without write ([#2384])
* Refactor
* Change Events#ssl_error signature from (error, peeraddr, peercert) to (error, ssl_socket) ([#2375])
* Consolidate option handling in Server, Server small refactors, doc chang ([#2373])
* Fri Sep 25 2020 Stephan Kulow updated to version 5.0.0 see installed History.md [#]# 5.0.0
* Features
* Allow compiling without OpenSSL and dynamically load files needed for SSL, add \'no ssl\' CI (#2305)
* EXPERIMENTAL: Add `fork_worker` option and `refork` command for reduced memory usage by forking from a worker process instead of the master process. (#2099)
* EXPERIMENTAL: Added `wait_for_less_busy_worker` config. This may reduce latency on MRI through inserting a small delay before re-listening on the socket if worker is busy (#2079).
* EXPERIMENTAL: Added `nakayoshi_fork` option. Reduce memory usage in preloaded cluster-mode apps by GCing before fork and compacting, where available. (#2093, #2256)
* Added pumactl `thread-backtraces` command to print thread backtraces (#2054)
* Added incrementing `requests_count` to `Puma.stats`. (#2106)
* Increased maximum URI path length from 2048 to 8192 bytes (#2167, #2344)
* `lowlevel_error_handler` is now called during a forced threadpool shutdown, and if a callable with 3 arguments is set, we now also pass the status code (#2203)
* Faster phased restart and worker timeout (#2220)
* Added `state_permission` to config DSL to set state file permissions (#2238)
* Added `Puma.stats_hash`, which returns a stats in Hash instead of a JSON string (#2086, #2253)
* `rack.multithread` and `rack.multiprocess` now dynamically resolved by `max_thread` and `workers` respectively (#2288)
* Deprecations, Removals and Breaking API Changes
* `--control` has been removed. Use `--control-url` (#1487)
* `worker_directory` has been removed. Use `directory`.
* min_threads now set by environment variables PUMA_MIN_THREADS and MIN_THREADS. (#2143)
* max_threads now set by environment variables PUMA_MAX_THREADS and MAX_THREADS. (#2143)
* max_threads default to 5 in MRI or 16 for all other interpreters. (#2143)
* preload by default if workers > 1 (#2143)
* Puma::Plugin.workers_supported? has been removed. Use Puma.forkable? instead. (#2143)
* `tcp_mode` has been removed without replacement. (#2169)
* Daemonization has been removed without replacement. (#2170)
* Changed #connected_port to #connected_ports (#2076)
* Configuration: `environment` is read from `RAILS_ENV`, if `RACK_ENV` can\'t be found (#2022)
* Log binding on http:// for TCP bindings to make it clickable
* Bugfixes
* Fix JSON loading issues on phased-restarts (#2269)
* Improve shutdown reliability (#2312, #2338)
* Close client http connections made to an ssl server with TLSv1.3 (#2116)
* Do not set user_config to quiet by default to allow for file config (#2074)
* Always close SSL connection in Puma::ControlCLI (#2211)
* Windows update extconf.rb for use with ssp and varied Ruby/MSYS2 combinations (#2069)
* Ensure control server Unix socket is closed on shutdown (#2112)
* Preserve `BUNDLE_GEMFILE` env var when using `prune_bundler` (#1893)
* Send 408 request timeout even when queue requests is disabled (#2119)
* Rescue IO::WaitReadable instead of EAGAIN for blocking read (#2121)
* Ensure `BUNDLE_GEMFILE` is unspecified in workers if unspecified in master when using `prune_bundler` (#2154)
* Rescue and log exceptions in hooks defined by users (on_worker_boot, after_worker_fork etc) (#1551)
* Read directly from the socket in #read_and_drop to avoid raising further SSL errors (#2198)
* Set `Connection: closed` header when queue requests is disabled (#2216)
* Pass queued requests to thread pool on server shutdown (#2122)
* Fixed a few minor concurrency bugs in ThreadPool that may have affected non-GVL Rubies (#2220)
* Fix `out_of_band` hook never executed if the number of worker threads is > 1 (#2177)
* Fix ThreadPool#shutdown timeout accuracy (#2221)
* Fix `UserFileDefaultOptions#fetch` to properly use `default` (#2233)
* Improvements to `out_of_band` hook (#2234)
* Prefer the rackup file specified by the CLI (#2225)
* Fix for spawning subprocesses with fork_worker option (#2267)
* Set `CONTENT_LENGTH` for chunked requests (#2287)
* JRuby - Add Puma::MiniSSL::Engine#init? and #teardown methods, run all SSL tests (#2317)
* Improve shutdown reliability (#2312)
* Resolve issue with threadpool waiting counter decrement when thread is killed
* Constrain rake-compiler version to 0.9.4 to fix `ClassNotFound` exception when using MiniSSL with Java8.
* Fix recursive `prune_bundler` (#2319).
* Ensure that TCP_CORK is usable
* Fix corner case when request body is chunked (#2326)
* Fix filehandle leak in MiniSSL (#2299)
* Refactor
* Remove unused loader argument from Plugin initializer (#2095)
* Simplify `Configuration.random_token` and remove insecure fallback (#2102)
* Simplify `Runner#start_control` URL parsing (#2111)
* Removed the IOBuffer extension and replaced with Ruby (#1980)
* Update `Rack::Handler::Puma.run` to use `
*
*options` (#2189)
* ThreadPool concurrency refactoring (#2220)
* JSON parse cluster worker stats instead of regex (#2124)
* Support parallel tests in verbose progress reporting (#2223)
* Refactor error handling in server accept loop (#2239)
* Sat Sep 12 2020 Manuel Schnitzer - updated to version 4.3.6
* Bugfixes
* Explicitly include ctype.h to fix compilation warning and build error on macOS with Xcode 12 (#2304)
* Don\'t require json at boot (#2269)
* Wed May 27 2020 Manuel Schnitzer - updated to version 4.3.5
* CVE-2020-11076, CVE-2020-11077: Fixed two separate HTTP smuggling vulnerabilities that used the Transfer-Encoding header
* Tue Mar 03 2020 Manuel Schnitzer - updated to version 4.3.3 [#] Bugfixes
* Fix: Fixes a problem where we weren\'t splitting headers correctly on newlines (#2132) [#] Security
* Fix: Prevent HTTP Response splitting via CR in early hints.
* Sat Dec 14 2019 Manuel Schnitzer - updated to version 4.3.1
* Fix: a poorly-behaved client could use keepalive requests to monopolize Puma\'s reactor and create a denial of service attack (CVE-2019-16770)
* Tue Nov 12 2019 Manuel Schnitzer - updated to version 4.3.0
* Features
* Strip whitespace at end of HTTP headers (#2010)
* Optimize HTTP parser for JRuby (#2012)
* Add SSL support for the control app and cli (#2046, #2052)
* Bugfixes
* Fix Errno::EINVAL when SSL is enabled and browser rejects cert (#1564)
* Fix pumactl defaulting puma to development if an environment was not specified (#2035)
* Fix closing file stream when reading pid from pidfile (#2048)
* Fix a typo in configuration option `--extra_runtime_dependencies` (#2050)
* Thu Aug 15 2019 Manuel Schnitzer - updated to version 4.1.0
* 4 features
* Add REQUEST_PATH on parse error message (#1831)
* You can now easily add custom log formatters with the `log_formatter` config option (#1816)
* Puma.stats now provides process start times (#1844)
* Add support for disabling TLSv1.1 (#1836)
* 7 bugfixes
* Fix issue where Puma was creating zombie process entries (#1887)
* Fix bugs with line-endings and chunked encoding (#1812)
* RACK_URL_SCHEME is now set correctly in all conditions (#1491)
* We no longer mutate global STDOUT/STDERR, particularly the sync setting (#1837)
* SSL read_nonblock no longer blocks (#1857)
* Swallow connection errors when sending early hints (#1822)
* Backtrace no longer dumped when invalid pumactl commands are run (#1863)
* 5 other
* Avoid casting worker_timeout twice (#1838)
* Removed a call to private that wasn\'t doing anything (#1882)
* README, Rakefile, docs and test cleanups (#1848, #1847, #1846, #1853, #1859, #1850, #1866, #1870, #1872, #1833, #1888)
* Puma.io has proper documentation now (https://puma.io/puma/)
* Added the Contributor Covenant CoC
* 1 known issue
* Some users are still experiencing issues surrounding socket activation and Unix sockets (#1842)
* Fri Jul 19 2019 Stephan Kulow - updated to version 4.0.1 see installed History.md
* Thu Mar 21 2019 manuel - updated to version 3.12.1
* 1 features
* Internal strings are frozen (#1649)
* 3 bugfixes
* Fix chunked ending check (#1607)
* Rack handler should use provided default host (#1700)
* Better support for detecting runtimes that support `fork` (#1630)
* Fri Jul 13 2018 factory-autoAATTkulow.org- updated to version 3.12.0 see installed History.md [#]# 3.12.0 / 2018-07-13
* 5 features:
* You can now specify which SSL ciphers the server should support, default is unchanged (#1478)
* The setting for Puma\'s `max_threads` is now in `Puma.stats` (#1604)
* Pool capacity is now in `Puma.stats` (#1579)
* Installs restricted to Ruby 2.2+ (#1506)
* `--control` is now deprecated in favor of `--control-url` (#1487)
* 2 bugfixes:
* Workers will no longer accept more web requests than they have capacity to process. This prevents an issue where one worker would accept lots of requests while starving other workers (#1563)
* In a test env puma now emits the stack on an exception (#1557)
* Thu Apr 12 2018 factory-autoAATTkulow.org- updated to version 3.11.4 see installed History.md [#]# 3.11.4 / 2018-04-12
* 2 features:
* Manage puma as a service using rc.d (#1529)
* Server stats are now available from a top level method (#1532)
* 5 bugfixes:
* Fix parsing CLI options (#1482)
* Order of stderr and stdout is made before redirecting to a log file (#1511)
* Init.d fix of `ps -p` to check if pid exists (#1545)
* Early hits bugfix (#1550)
* Purge interrupt queue when closing socket fails (#1553)
* Tue Mar 20 2018 factory-autoAATTkulow.org- updated to version 3.11.3 see installed History.md [#]# 3.11.3 / 2018-03-05
* 3 bugfixes:
* Add closed? to MiniSSL::Socket for use in reactor (#1510)
* Handle EOFError at the toplevel of the server threads (#1524) (#1507)
* Deal with zero sized bodies when using SSL (#1483)
* Thu Feb 08 2018 cooloAATTsuse.com- updated to version 3.11.2 see installed History.md [#]# 3.11.2 / 2018-01-19
* 1 bugfix:
* Deal with read\\_nonblock returning nil early [#]# 3.11.1 / 2018-01-18
* 1 bugfix:
* Handle read\\_nonblock returning nil when the socket close (#1502)
* Sun Dec 03 2017 cooloAATTsuse.com- updated to version 3.11.0 see installed History.md [#]# 3.11.0 / 2017-11-20
* 2 features:
* HTTP 203 Early Hints (#1403)
* 421/451 status codes now have correct status messages attached (#1435)
* 9 bugfixes:
* Environment config files (/config/puma/.rb) load correctly (#1340)
* Specify windows dependencies correctly (#1434, #1436)
* puma/events required in test helper (#1418)
* Correct control CLI\'s option help text (#1416)
* Remove a warning for unused variable in mini_ssl (#1409)
* Correct pumactl docs argument ordering (#1427)
* Fix an uninitialized variable warning in server.rb (#1430)
* Fix docs typo/error in Launcher init (#1429)
* Deal with leading spaces in RUBYOPT (#1455)
* 2 other:
* Add docs about internals (#1425, #1452)
* Tons of test fixes from AATTMSP-Greg (#1439, #1442, #1464)
* Mon Sep 11 2017 cooloAATTsuse.com- updated to version 3.10.0 see installed History.md [#]# 3.10.0 / 2017-08-17
* 3 features:
* The status server has a new /gc and /gc-status command. (#1384)
* The persistent and first data timeouts are now configurable (#1111)
* Implemented RFC 2324 (#1392)
* 12 bugfixes:
* Not really a Puma bug, but AATTNickolasVashchenko created a gem to workaround a Ruby bug that some users of Puma may be experiencing. See README for more. (#1347)
* Fix hangups with SSL and persistent connections. (#1334)
* Fix Rails double-binding to a port (#1383)
* Fix incorrect thread names (#1368)
* Fix issues with /etc/hosts and JRuby where localhost addresses were not correct. (#1318)
* Fix compatibility with RUBYOPT=\"--enable-frozen-string-literal\" (#1376)
* Fixed some compiler warnings (#1388)
* We actually run the integration tests in CI now (#1390)
* No longer shipping unnecessary directories in the gemfile (#1391)
* If RUBYOPT is nil, we no longer blow up on restart. (#1385)
* Correct response to SIGINT (#1377)
* Proper exit code returned when we receive a TERM signal (#1337)
* 3 refactors:
* Various test improvements from AATTgrosser
* Rubocop (#1325)
* Hoe has been removed (#1395)
* 1 known issue:
* Socket activation doesn\'t work in JRuby. Their fault, not ours. (#1367)
* Tue Jun 06 2017 cooloAATTsuse.com- updated to version 3.9.1 see installed History.md [#]# 3.9.1 / 2017-06-03
* 2 bugfixes:
* Fixed compatibility with older Bundler versions (#1314)
* Some internal test/development cleanup (#1311, #1313) [#]# 3.9.0 / 2017-06-01
* 2 features:
* The ENV is now reset to its original values when Puma restarts via USR1/USR2 (#1260) (MRI only, no JRuby support)
* Puma will no longer accept more clients than the maximum number of threads. (#1278)
* 9 bugfixes:
* Reduce information leakage by preventing HTTP parse errors from writing environment hashes to STDERR (#1306)
* Fix SSL/WebSocket compatibility (#1274)
* HTTP headers with empty values are no longer omitted from responses. (#1261)
* Fix a Rack env key which was set to nil. (#1259)
* peercert has been implemented for JRuby (#1248)
* Fix port settings when using rails s (#1277, #1290)
* Fix compat w/LibreSSL (#1285)
* Fix restarting Puma w/symlinks and a new Gemfile (#1282)
* Replace Dir.exists? with Dir.exist? (#1294)
* 1 known issue:
* A bug in MRI 2.2+ can result in IOError: stream closed. See #1206. This issue has existed since at least Puma 3.6, and probably further back.
* 1 refactor:
* Lots of test fixups from AATTgrosser.
* Mon Jun 05 2017 mrueckertAATTsuse.de- fix gem2rpm.yml syntax
* Thu Mar 16 2017 cooloAATTsuse.com- updated to version 3.8.2 see installed History.md [#]# 3.8.2 / 2017-03-14
* 1 bugfix:
* Deal with getsockopt with TCP\\_INFO failing for sockets that say they\'re TCP but aren\'t really. (#1241) [#]# 3.8.1 / 2017-03-10
* 1 bugfix:
* Remove method call to method that no longer exists (#1239) [#]# 3.8.0 / 2017-03-09
* 2 bugfixes:
* Port from rack handler does not take precedence over config file in Rails 5.1.0.beta2+ and 5.0.1.rc3+ (#1234)
* The `tmp/restart.txt` plugin no longer restricts the user from running more than one server from the same folder at a time (#1226)
* 1 feature:
* Closed clients are aborted to save capacity (#1227)
* 1 refactor:
* Bundler is no longer a dependency from tests (#1213)
* Tue Feb 21 2017 cooloAATTsuse.com- updated to version 3.7.1 see installed History.md [#]# 3.7.1 / 2017-02-20
* 2 bugfixes:
* Fix typo which blew up MiniSSL (#1182)
* Stop overriding command-line options with the config file (#1203)
* Sat Jan 28 2017 cooloAATTsuse.com- updated to version 3.7.0 History.txt removed upstream
* Fri Dec 09 2016 cooloAATTsuse.com- updated to version 3.6.2 see installed History.txt === 3.6.2 / 2016-11-22
* 1 bug fix:
* Revert #1118/Fix access priorities of each level in LeveledOptions. This had an unintentional side effect of changing the importance of command line options, such as -p.
* Tue Nov 22 2016 cooloAATTsuse.com- updated to version 3.6.1 see installed History.txt === 3.6.1 / 2016-11-21
* 8 bug fixes:
* Fix Puma start in init.d script.
* Fix default SSL mode back to none. Fixes #1036
* Fixed the issue of AATTlisteners getting nil io, fix rails restart (#1120)
* More gracefully deal with SSL sessions. Fixes #1002
* Prevent short term thread churn.
* Provide write as <<. Fixes #1089
* Fix access priorities of each level in LeveledOptions - fixes TTIN.
* Stub description files updated for init.d.
* 2 new project committers:
* Nate Berkopec (AATTnateberkopec)
* Richard Schneeman (AATTschneems)
* Tue Jul 26 2016 cooloAATTsuse.com- updated to version 3.6.0 see installed History.txt === 3.6.0 / 2016-07-24
* 12 bug fixes:
* Add ability to detect a shutting down server. Fixes #932
* Add support for Expect: 100-continue. Fixes #519
* Check SSLContext better. Fixes #828
* Clarify behavior of \'-t \'. Fixes #984
* Don\'t default to VERIFY_PEER. Fixes #1028
* Don\'t use ENV[\'PWD\'] on windows. Fixes #1023
* Enlarge the scope of catching app exceptions. Fixes #1027
* Execute background hooks after daemonizing. Fixes #925
* Handle HUP as a stop unless there is IO redirection. Fixes #911
* Implement chunked request handling. Fixes #620
* Just rescue exception to return a 500. Fixes #1027
* Redirect IO in the jruby daemon mode. Fixes #778
* Sat Jul 23 2016 cooloAATTsuse.com- updated to version 3.5.2 see installed History.txt === 3.5.2 / 2016-07-20
* 1 bug fix:
* Don\'t let persistent_timeout be nil
* 1 PR merged:
* Merge pull request #1021 from benzrf/patch-1 === 3.5.1 / 2016-07-20
* 1 bug fix:
* Be sure to only listen on host:port combos once. Fixes #1022
* Wed Jul 20 2016 cooloAATTsuse.com- updated to version 3.5.0 see installed History.txt === 3.5.0 / 2016-07-18
* 1 minor features:
* Allow persistent_timeout to be configured via the dsl.
* 9 bug fixes:
* Allow a bare % in a query string. Fixes #958
* Explicitly listen on all localhost addresses. Fixes #782
* Fix `TCPLogger` log error in tcp cluster mode.
* Fix puma/puma#968 Cannot bind SSL port due to missing verify_mode option
* Fix puma/puma#968 Default verify_mode to peer
* Log any exceptions in ThreadPool. Fixes #1010
* Silence connection errors in the reactor. Fixes #959
* Tiny fixes in hook documentation for #840
* It should not log requests if we want it to be quiet
* 5 doc fixes:
* Add How to stop Puma on Heroku using plugins to the example directory
* Provide both hot and phased restart in jungle script
* Update reference to the instances management script
* Update default number of threads
* Fix typo in example config
* 14 PRs merged:
* Merge pull request #1007 from willnet/patch-1
* Merge pull request #1014 from jeznet/patch-1
* Merge pull request #1015 from bf4/patch-1
* Merge pull request #1017 from jorihardman/configurable_persistent_timeout
* Merge pull request #954 from jf/master
* Merge pull request #955 from jf/add-request-info-to-standard-error-rescue
* Merge pull request #956 from maxkwallace/master
* Merge pull request #960 from kmayer/kmayer-plugins-heroku-restart
* Merge pull request #969 from frankwong15/master
* Merge pull request #970 from willnet/delete-blank-document
* Merge pull request #974 from rocketjob/feature/name_threads
* Merge pull request #977 from snow/master
* Merge pull request #981 from zach-chai/patch-1
* Merge pull request #993 from scorix/master
* Tue Apr 12 2016 cooloAATTsuse.com- updated to version 3.4.0 see installed History.txt === 3.4.0 / 2016-04-07
* 2 minor features:
* Add ability to force threads to stop on shutdown. Fixes #938
* Detect and commit seppuku when fork(2) fails. Fixes #529
* 3 unknowns:
* Ignore errors trying to update the backport tables. Fixes #788
* Invoke the lowlevel_error in more places to allow for exception tracking. Fixes #894
* Update the query string when an absolute URI is used. Fixes #937
* 5 doc fixes:
* Add Process Monitors section to top-level README
* Better document the hooks. Fixes #840
* docs/system.md sample config refinements and elaborations
* Fix typos at couple of places.
* Cleanup warnings
* 3 PRs merged:
* Merge pull request #945 from dekellum/systemd-docs-refined
* Merge pull request #946 from vipulnsward/rm-pid
* Merge pull request #947 from vipulnsward/housekeeping-typos
* Wed Apr 06 2016 cooloAATTsuse.com- updated to version 3.3.0 see installed History.txt === 3.3.0 / 2016-04-05
* 2 minor features:
* Allow overriding options of Configuration object
* Rename to inherit_ssl_listener like inherit_tcp|unix
* 2 doc fixes:
* Add docs/systemd.md (with socket activation sub-section)
* Document UNIX signals with cluster on README.md
* 3 PRs merged:
* Merge pull request #936 from prathamesh-sonpatki/allow-overriding-config-options
* Merge pull request #940 from kyledrake/signalsdoc
* Merge pull request #942 from dekellum/socket-activate-improve === 3.2.0 / 2016-03-20
* 1 deprecation removal:
* Delete capistrano.rb
* 3 bug fixes:
* Detect gems.rb as well as Gemfile
* Simplify and fix logic for directory to use when restarting for all phases
* Speed up phased-restart start
* 2 PRs merged:
* Merge pull request #927 from jlecour/gemfile_variants
* Merge pull request #931 from joneslee85/patch-10
* Sat Mar 19 2016 cooloAATTsuse.com- updated to version 3.1.1 see installed History.txt === 3.1.1 / 2016-03-17
* 4 bug fixes:
* Disable USR1 usage on JRuby
* Fixes #922 - Correctly define file encoding as UTF-8
* Set a more explicit SERVER_SOFTWARE Rack variable
* Show RUBY_ENGINE_VERSION if available. Fixes #923
* 3 PRs merged:
* Merge pull request #912 from tricknotes/fix-allow-failures-in-travis-yml
* Merge pull request #921 from swrobel/patch-1
* Merge pull request #924 from tbrisker/patch-1
* Sun Mar 06 2016 cooloAATTsuse.com- updated to version 3.1.0 see installed History.txt === 3.1.0 / 2016-03-05
* 1 minor feature:
* Add \'import\' directive to config file. Fixes #916
* 5 bug fixes:
* Add \'fetch\' to options. Fixes #913
* Fix jruby daemonization. Fixes #918
* Recreate the proper args manually. Fixes #910
* Require \'time\' to get iso8601. Fixes #914
* Wed Mar 02 2016 cooloAATTsuse.com- updated to version 3.0.2 see installed History.txt === 3.0.2 / 2016-02-26
* 5 bug fixes:
* Fix \'undefined local variable or method `pid` for #\' when execute pumactl with `--pid` option.
* Fix \'undefined method `windows?` for Puma:Module\' when execute pumactl.
* Harden tmp_restart against errors related to the restart file
* Make `plugin :tmp_restart` behavior correct in Windows.
* fix uninitialized constant Puma::ControlCLI::StateFile
* 3 PRs merged:
* Merge pull request #901 from mitto/fix-pumactl-uninitialized-constant-statefile
* Merge pull request #902 from corrupt952/fix_undefined_method_and_variable_when_execute_pumactl
* Merge pull request #905 from Eric-Guo/master
* Fri Feb 26 2016 cooloAATTsuse.com- updated to version 3.0.1 see installed History.txt === 3.0.1 / 2016-02-25
* 1 bug fix:
* Removed the experimental support for async.callback as it broke websockets entirely. Seems no server has both hijack and async.callback and thus faye is totally confused what to do and doesn\'t work. === 3.0.0 / 2016-02-25
* 2 major changes:
* Ruby pre-2.0 is no longer supported. We\'ll do our best to not add features that break those rubies but will no longer be testing with them.
* Don\'t log requests by default. Fixes #852
* 2 major features:
* Plugin support! Plugins can interact with configuration as well as provide augment server functionality!
* Experimental env[\'async.callback\'] support
* 4 minor features:
* Listen to unix socket with provided backlog if any
* Improves the clustered stats to report worker stats
* Pass the env to the lowlevel_error handler. Fixes #854
* Treat path-like hosts as unix sockets. Fixes #824
* 5 bug fixes:
* Clean thread locals when using keepalive. Fixes #823
* Cleanup compiler warnings. Fixes #815
* Expose closed? for use by the reactor. Fixes #835
* Move signal handlers to separate method to prevent space leak. Fixes #798
* Signal not full on worker exit #876
* 5 doc fixes:
* Update README.md with various grammar fixes
* Use newest version of Minitest
* Add directory configuration docs, fix typo [ci skip]
* Remove old COPYING notice. Fixes #849
* 10 merged PRs:
* Merge pull request #871 from deepj/travis
* Merge pull request #874 from wallclockbuilder/master
* Merge pull request #883 from dadah89/igor/trim_only_worker
* Merge pull request #884 from uistudio/async-callback
* Merge pull request #888 from mlarraz/tick_minitest
* Merge pull request #890 from todd/directory_docs
* Merge pull request #891 from ctaintor/improve_clustered_status
* Merge pull request #893 from spastorino/add_missing_require
* Merge pull request #897 from zendesk/master
* Merge pull request #899 from kch/kch-readme-fixes
* Thu Jan 28 2016 cooloAATTsuse.com- updated to version 2.16.0 see installed History.txt === 2.16.0 / 2016-01-27
* 7 minor features:
* Add \'set_remote_address\' config option
* Allow to run puma in silent mode
* Expose cli options in DSL
* Support passing JRuby keystore info in ssl_bind DSL
* Allow umask for unix:/// style control urls
* Expose `old_worker_count` in stats url
* Support TLS client auth (verify_mode) in jruby
* 7 bug fixes:
* Don\'t persist before_fork hook in state file
* Reload bundler before pulling in rack. Fixes #859
* Remove NEWRELIC_DISPATCHER env variable
* Cleanup C code
* Use Timeout.timeout instead of Object.timeout
* Make phased restarts faster
* Ignore the case of certain headers, because HTTP
* 1 doc changes:
* Test against the latest Ruby 2.1, 2.2, 2.3, head and JRuby 9.0.4.0 on Travis
* 12 merged PRs
* Merge pull request #822 from kwugirl/remove_NEWRELIC_DISPATCHER
* Merge pull request #833 from joemiller/jruby-client-tls-auth
* Merge pull request #837 from YuriSolovyov/ssl-keystore-jruby
* Merge pull request #839 from mezuka/master
* Merge pull request #845 from deepj/timeout-deprecation
* Merge pull request #846 from sriedel/strip_before_fork
* Merge pull request #850 from deepj/travis
* Merge pull request #853 from Jeffrey6052/patch-1
* Merge pull request #857 from zendesk/faster_phased_restarts
* Merge pull request #858 from mlarraz/fix_some_warnings
* Merge pull request #860 from zendesk/expose_old_worker_count
* Merge pull request #861 from zendesk/allow_control_url_umask
* Mon Nov 09 2015 cooloAATTsuse.com- updated to version 2.15.3 see installed History.txt === 2.15.3 / 2015-11-07
* 1 bug fix:
* Fix JRuby parser
* Sat Nov 07 2015 cooloAATTsuse.com- updated to version 2.15.2 see installed History.txt === 2.15.2 / 2015-11-06
* 2 bug fixes:
* ext/puma_http11: handle duplicate headers as per RFC
* Only set ctx.ca iff there is a params[\'ca\'] to set with.
* 2 PRs merged:
* Merge pull request #818 from unleashed/support-duplicate-headers
* Merge pull request #819 from VictorLowther/fix-ca-and-verify_null-exception === 2.15.1 / 2015-11-06
* 1 bug fix:
* Allow older openssl versions === 2.15.0 / 2015-11-06
* 6 minor features:
* Allow setting ca without setting a verify mode
* Make jungle for init.d support rbenv
* Use SSL_CTX_use_certificate_chain_file for full chain
* cluster: add worker_boot_timeout option
* configuration: allow empty tags to mean no tag desired
* puma/cli: support specifying STD{OUT,ERR} redirections and append mode
* 5 bug fixes:
* Disable SSL Compression
* Fix bug setting worker_directory when using a symlink directory
* Fix error message in DSL that was slightly inaccurate
* Pumactl: set correct process name. Fixes #563
* thread_pool: fix race condition when shutting down workers
* 10 doc fixes:
* Add before_fork explanation in Readme.md
* Correct spelling in DEPLOYMENT.md
* Correct spelling in docs/nginx.md
* Fix spelling errors.
* Fix typo in deployment description
* Fix typos (it\'s -> its) in events.rb and server.rb
* fixing for typo mentioned in #803
* Spelling correction for README
* thread_pool: fix typos in comment
* More explicit docs for worker_timeout
* 18 PRs merged:
* Merge pull request #768 from nathansamson/patch-1
* Merge pull request #773 from rossta/spelling_corrections
* Merge pull request #774 from snow/master
* Merge pull request #781 from sunsations/fix-typo
* Merge pull request #791 from unleashed/allow_empty_tags
* Merge pull request #793 from robdimarco/fix-working-directory-symlink-bug
* Merge pull request #794 from peterkeen/patch-1
* Merge pull request #795 from unleashed/redirects-from-cmdline
* Merge pull request #796 from cschneid/fix_dsl_message
* Merge pull request #799 from annafw/master
* Merge pull request #800 from liamseanbrady/fix_typo
* Merge pull request #801 from scottjg/ssl-chain-file
* Merge pull request #802 from scottjg/ssl-crimes
* Merge pull request #804 from burningTyger/patch-2
* Merge pull request #809 from unleashed/threadpool-fix-race-in-shutdown
* Merge pull request #810 from vlmonk/fix-pumactl-restart-bug
* Merge pull request #814 from schneems/schneems/worker_timeout-docs
* Merge pull request #817 from unleashed/worker-boot-timeout
* Sat Sep 19 2015 cooloAATTsuse.com- updated to version 2.14.0 see installed History.txt === 2.14.0 / 2015-09-18
* 1 minor feature:
* Make building with SSL support optional
* 1 bug fix:
* Use Rack::Builder if available. Fixes #735
* Mon Aug 24 2015 cooloAATTsuse.com- updated to version 2.13.4 see installed History.txt === 2.13.4 / 2015-08-16
* 1 bug fix:
* Use the environment possible set by the config early and from the config file later (if set). === 2.13.3 / 2015-08-15 Seriously, I need to revamp config with tests.
* 1 bug fix:
* Fix preserving options before cleaning for state. Fixes #769 === 2.13.2 / 2015-08-15 The \"clearly I don\'t have enough tests for the config\" release.
* 1 bug fix:
* Fix another place binds wasn\'t initialized. Fixes #767 === 2.13.1 / 2015-08-15
* 2 bug fixes:
* Fix binds being masked in config files. Fixes #765
* Use options from the config file properly in pumactl. Fixes #764
* Sat Aug 15 2015 cooloAATTsuse.com- updated to version 2.13.0 see installed History.txt === 2.13.0 / 2015-08-14
* 1 minor feature:
* Add before_fork hooks option.
* 3 bug fixes:
* Check for OPENSSL_NO_ECDH before using ECDH
* Eliminate logging overhead from JRuby SSL
* Prefer cli options over config file ones. Fixes #669
* 1 deprecation:
* Add deprecation warning to capistrano.rb. Fixes #673
* 4 PRs merged:
* Merge pull request #668 from kcollignon/patch-1
* Merge pull request #754 from nathansamson/before_boot
* Merge pull request #759 from BenV/fix-centos6-build
* Merge pull request #761 from looker/no-log
* Wed Aug 05 2015 cooloAATTsuse.com- updated to version 2.12.3 see installed History.txt === 2.12.3 / 2015-08-03
* 8 minor bugs fixed:
* Fix Capistrano \'uninitialized constant Puma\' error.
* Fix some ancient and incorrect error handling code
* Fix uninitialized constant error
* Remove toplevel rack interspection, require rack on load instead
* Skip empty parts when chunking
* Switch from inject to each in config_ru_binds iteration
* Wrap SSLv3 spec in version guard.
* ruby 1.8.7 compatibility patches
* 4 PRs merged:
* Merge pull request #742 from deivid-rodriguez/fix_missing_require
* Merge pull request #743 from matthewd/skip-empty-chunks
* Merge pull request #749 from huacnlee/fix-cap-uninitialized-puma-error
* Merge pull request #751 from costi/compat_1_8_7
* 1 test fix:
* Add 1.8.7, rbx-1 (allow failures) to Travis.
* Sat Jul 18 2015 cooloAATTsuse.com- updated to version 2.12.2 see installed History.txt === 2.12.2 / 2015-07-17
* 2 bug fix:
* Pull over and use Rack::URLMap. Fixes #741
* Stub out peercert on JRuby for now. Fixes #739
* Fri Jul 17 2015 cooloAATTsuse.com- updated to version 2.12.1 see installed History.txt === 2.12.1 / 2015-07-16
* 2 bug fixes:
* Use a constant format. Fixes #737
* Use strerror for Windows sake. Fixes #733
* 1 doc change:
* typo fix: occured -> occurred
* 1 PR merged:
* Merge pull request #736 from paulanunda/paulanunda/typo-fix
* Wed Jul 15 2015 cooloAATTsuse.com- updated to version 2.12.0 see installed History.txt === 2.12.0 / 2015-07-14
* X bug fixes:
* Add thread reaping to thread pool
* Do not automatically use chunked responses when hijacked
* Do not suppress Content-Length on partial hijack
* Don\'t allow any exceptions to terminate a thread
* Handle ENOTCONN client disconnects when setting REMOTE_ADDR
* Handle very early exit of cluster mode. Fixes #722
* Install rack when running tests on travis to use rack/lint
* Make puma -v and -h return success exit code
* Make pumactl load config/puma.rb by default
* Pass options from pumactl properly when pruning. Fixes #694
* Remove rack dependency. Fixes #705
* Remove the default Content-Type: text/plain
* Add Client Side Certificate Auth
* X doc/test changes:
* Added example sourcing of environment vars
* Added tests for bind configuration on rackup file
* Fix example config text
* Update DEPLOYMENT.md
* Update Readme with example of custom error handler
* ci: Improve Travis settings
* ci: Start running tests against JRuby 9k on Travis
* ci: Convert to container infrastructure for travisci
* X ops changes:
* Check for system-wide rbenv
* capistrano: Add additional env when start rails
* X PRs merged:
* Merge pull request #686 from jjb/patch-2
* Merge pull request #693 from rob-murray/update-example-config
* Merge pull request #697 from spk/tests-bind-on-rackup-file
* Merge pull request #699 from deees/fix/require_rack_builder
* Merge pull request #701 from deepj/master
* Merge pull request #702 from Jimdo/thread-reaping
* Merge pull request #703 from deepj/travis
* Merge pull request #704 from grega/master
* Merge pull request #709 from lian/master
* Merge pull request #711 from julik/master
* Merge pull request #712 from yakara-ltd/pumactl-default-config
* Merge pull request #715 from RobotJiang/master
* Merge pull request #725 from rwz/master
* Merge pull request #726 from strenuus/handle-client-disconnect
* Merge pull request #729 from allaire/patch-1
* Merge pull request #730 from iamjarvo/container-infrastructure
* Tue May 19 2015 cooloAATTsuse.com- updated to version 2.11.3 see installed History.txt === 2.11.3 / 2015-05-18
* 5 bug fixes:
* Be sure to unlink tempfiles after a request. Fixes #690
* Coerce the key to a string before checking. (thar be symbols). Fixes #684
* Fix hang on bad SSL handshake
* Remove `enable_SSLv3` support from JRuby
* 1 PR merged:
* Merge pull request #698 from looker/hang-handshake
* Sun Apr 12 2015 cooloAATTsuse.com- updated to version 2.11.2
* 2 minor features:
* Add `on_worker_fork` hook, which allows to mimic Unicorn\'s behavior
* Add shutdown_debug config option
* 4 bug fixes:
* Fix the Config constants not being available in the DSL. Fixes #683
* Ignore multiple port declarations
* Proper \'Connection\' header handling compatible with HTTP 1.[01] protocols
* Use \"Puma\" instead of \"puma\" to reporting to New Relic
* 1 doc fixes:
* Add Gitter badge.
* 6 PRs merged:
* Merge pull request #657 from schneems/schneems/puma-once-port
* Merge pull request #658 from Tomohiro/newrelic-dispatcher-default-update
* Merge pull request #662 from basecrm/connection-compatibility
* Merge pull request #664 from fxposter/on-worker-fork
* Merge pull request #667 from JuanitoFatas/doc/gemspec
* Fri Feb 13 2015 cooloAATTsuse.com- updated to version 2.11.1
* Fri Feb 06 2015 cooloAATTsuse.com- updated to version 2.11.0
* 9 bug fixes:
* Add mode as an additional bind option to unix sockets. Fixes #630
* Advertise HTTPS properly after a hot restart
* Don\'t write lowlevel_error_handler to state
* Fix phased restart with stuck requests
* Handle spaces in the path properly. Fixes #622
* Set a default REMOTE_ADDR to avoid using peeraddr on unix sockets. Fixes #583
* Skip device number checking on jruby. Fixes #586
* Update extconf.rb to compile correctly on OS X
* redirect io right after daemonizing so startup errors are shown. Fixes #359
* 6 minor features:
* Add a configuration option that prevents puma from queueing requests.
* Add reload_worker_directory
* Add the ability to pass environment variables to the init script (for Jungle).
* Add the proctitle tag to the worker. Fixes #633
* Infer a proctitle tag based on the directory
* Update lowlevel error message to be more meaningful.
* 10 PRs merged:
* Merge pull request #478 from rubencaro/master
* Merge pull request #610 from kwilczynski/master
* Merge pull request #611 from jasonl/better-lowlevel-message
* Merge pull request #616 from jc00ke/master
* Merge pull request #623 from raldred/patch-1
* Merge pull request #628 from rdpoor/master
* Merge pull request #634 from deepj/master
* Merge pull request #637 from raskhadafi/patch-1
* Merge pull request #639 from ebeigarts/fix-phased-restarts
* Merge pull request #640 from codehotter/issue-612-dependent-requests-deadlock === 2.10.2 / 2014-11-26
* 1 bug fix:
* Conditionalize thread local cleaning, fixes perf degradation fix The code to clean out all Thread locals adds pretty significant overhead to a each request, so it has to be turned on explicitly if a user needs it.
 
ICM