Julian Brost
d8cf80e996
third-party: update GetGitRevisionDescription CMake module
...
The new version includes functionality to prevent using version information
from parent directories of the source root directory.
wget -O third-party/cmake/GetGitRevisionDescription.cmake https://raw.githubusercontent.com/rpavlik/cmake-modules/main/GetGitRevisionDescription.cmake
wget -O third-party/cmake/GetGitRevisionDescription.cmake.in https://raw.githubusercontent.com/rpavlik/cmake-modules/main/GetGitRevisionDescription.cmake.in
2022-01-03 18:37:34 +01:00
Julian Brost
a379f6e08c
Make MySQL schema version in full schema file and upgrade files consistent
...
In the 2.12.6 release, the full schema file sets the version to 1.14.3, whereas
the latest available upgrade file 2.11.0.sql sets it to 1.15.0. Therefore, ship
a new upgrade file 2.12.7.sql for all users who imported their schema with
version 2.11.0 or later and never performed an upgrade since then. Their
databases incorrectly state schema version 1.14.3 and is bumped to the correct
version 1.15.0 by the upgrade. Additionally, the version number in the full
schema is also bumped to the correct version 1.15.0.
2021-12-16 16:04:54 +01:00
Alexander A. Klimov
eb71fb7529
Avoid "type" key in dicts being part of object state attrs
...
not to confuse the state file deserializator with e.g. `"type":32` on startup.
That would unexpectedly restore null (not `{"type":32}`) as there's no type "32".
refs #8186
2021-12-13 17:56:12 +01:00
Noah Hilverling
e6d9f95a13
Merge pull request from GHSA-cxfm-8j5v-5qr2
...
Add TLS server certificate validation to ElasticsearchWriter, GelfWriter and InfluxdbWriter (v2)
2021-08-19 13:52:29 +02:00
Noah Hilverling
88ed37454b
Add 2.12.6 changelog and bump VERSION
v2.12.6
2021-08-18 17:41:01 +02:00
Julian Brost
b7dd909a30
GelfWriter: show error message of exceptions
2021-08-17 16:38:54 +02:00
Julian Brost
6db8795ca4
InfluxdbWriter: actually verify TLS server certificates
...
And add a new option ssl_insecure_noverify to explicitly disable it if desired.
2021-08-17 16:38:39 +02:00
Julian Brost
d7133ae429
GelfWriter: actually verify TLS server certificates
...
And add a new option insecure_noverify to explicitly disable it if desired.
2021-08-17 16:33:18 +02:00
Julian Brost
bf535969ac
ElasticsearchWriter: actually verify TLS server certificates
...
And add a new option insecure_noverify to explicitly disable it if desired.
2021-08-17 16:33:18 +02:00
Julian Brost
8910abc588
Enable hostname verification in UnbufferedAsioTlsStream
2021-08-17 16:33:18 +02:00
Alexander Aleksandrovič Klimov
5eeb434f3b
Merge pull request #8906 from Icinga/probot/sync-changelog/241b2be0ec51fff0012be5f439e5a3f4f78a4403
...
CHANGELOG.md: add v2.11.10
2021-07-15 18:20:16 +02:00
Julian Brost
dc6d79f3f4
CHANGELOG.md: add v2.11.10
2021-07-15 10:27:18 +00:00
Alexander Aleksandrovič Klimov
241b2be0ec
Merge pull request #8904 from Icinga/Al2Klimov-patch-3
...
Update .mailmap
2021-07-15 12:27:06 +02:00
Alexander Aleksandrovič Klimov
693d4e3962
Update .mailmap
2021-07-15 11:27:32 +02:00
Julian Brost
31545cbe65
Merge pull request from GHSA-98wp-jc6q-x5q5
...
API: hide ApiListener#ticket_salt (2.12)
2021-07-15 11:13:35 +02:00
Julian Brost
730860bf0f
Merge pull request from GHSA-wrpw-pmr8-qgj7
...
Remove passwords from API (2.12)
2021-07-15 11:12:29 +02:00
Julian Brost
ce26bf9a4c
Icinga 2.12.5
v2.12.5
2021-07-09 16:15:24 +02:00
Alexander A. Klimov
b5b83fa515
API: hide ApiListener#ticket_salt
2021-07-09 09:30:45 +02:00
Julian Brost
843353ab69
Remove passwords from API
...
IdoMysqlConnection, IdoPgsqlConnection, IcingaDB, and ElasticsearchWriter
require passwords in their configuration to authenticate against external
services. This commit ensures that these can no longer be accessed using the
API.
2021-07-09 09:05:05 +02:00
Julian Brost
289a872eaf
Merge pull request #8865 from Icinga/feature/improve-crashlog-212
...
Improve crashlog
2021-07-09 08:21:44 +02:00
Julian Brost
4a1e6528ea
Merge pull request #8889 from Icinga/bugfix/trigger-fixed-downtimes-immediately-212
...
Downtime#Start(): trigger fixed downtimes immediately instead of waiting for the timer
2021-07-08 15:33:11 +02:00
Julian Brost
7bfe896efb
Stacktrace test: try to prevent inlining even harder
...
- Explicitly disable optimizations for MSVC
- Make stack_test_func_a bigger
2021-07-08 14:53:15 +02:00
Julian Brost
d8ab328c33
Add comments to stack trace formatter and test case
2021-07-08 14:53:15 +02:00
Julian Brost
c3f77be473
Compile with -D_GNU_SOURCE
...
Needed by `boost::stacktrace` for `_Unwind_Backtrace()`.
2021-07-08 14:53:15 +02:00
Julian Brost
1a82a9fa87
CMakeLists: use HAVE_LIBEXECINFO only after actually checking for it
...
So far, the check that actually sets HAVE_LIBEXECINFO was executed after
it was already used to add dependencies.
2021-07-08 14:53:15 +02:00
Julian Brost
14987274dc
Add a test case for the stack trace formatter
2021-07-08 14:53:15 +02:00
Julian Brost
f5873a8e75
Use backtrace_symbols() when printing stack traces on FreeBSD
...
Unfortunately, the symbol resolution of boost::stacktrace is broken on
FreeBSD, therefore fall back to using backtrace_symbols() to print the
stack trace saved by Boost.
Additionally, -D_GNU_SOURCE is required on FreeBSD for the
_Unwind_Backtrace function used by boost::stacktrace.
2021-07-08 14:53:15 +02:00
Julian Brost
a2e5cfd34f
Crash handlers: use more compact string representation
2021-07-08 14:53:15 +02:00
Julian Brost
2310cdb4fa
Begin crash log for SIGABRT with error message and timestamp
...
This makes the format more similar to what the uncaught C++ and SEH
exception handlers write. Previously there was no indication in the
crash log that a SIGABRT happened.
2021-07-08 14:53:15 +02:00
Julian Brost
cb3febfd2a
Windows: require at least MSVC 19.20 to build
...
Older versions of MSVC fail to rethrow an unhandled C++ exception (using
`throw;`) in the termination handler (`std::set_terminate`), however
Icinga relies on this behavior in its crash handler
(`Application::ExceptionHandler`).
2021-07-08 14:53:15 +02:00
Julian Brost
51bb751f23
docs: mention use of boost::stacktrace
2021-07-08 14:53:15 +02:00
Julian Brost
2330ab59f8
Add some comments to __cxa_throw
...
Maybe this will save the next person who has to look at this code some
time. Please don't blame me for the implementation, I'm just trying to
reconstruct what it does.
2021-07-08 14:53:15 +02:00
Julian Brost
9fcc781172
Restructure stack and context trace selection in DiagnosticInformation and document behavior
...
The logic for selecting the traces to print stays the same, but there
are fewer nested ifs now. This changes the format of the returned string
a bit by adding a heading for both traces.
2021-07-08 14:53:15 +02:00
Julian Brost
df59aa0087
Add documentation for cast_exception function
2021-07-08 14:53:15 +02:00
Julian Brost
996f280bfc
Pass fallback stacktrace to DiagnosticInformation in terminate handler
...
By default, DiagnosticInformation uses the stack trace saved when the
exception was thrown, but this mechanism is not in use on Windows.
Gathering a stacktrace in the terminate handler serves as a fallback.
2021-07-08 14:53:15 +02:00
Julian Brost
8b2f4636db
Replace icinga::StackTrace with boost::stacktrace::stacktrace
...
Provides roughly the same functionality but works better on certain
platforms (especially Windows) and is less code to maintain.
2021-07-08 14:53:15 +02:00
Julian Brost
4a29c39eba
Print details in uncaught SEH exception handler
2021-07-08 14:53:15 +02:00
Julian Brost
8b67e4a637
Move error message and time to the beginning of the SEH crash log
...
This is more similar to the normal exception crashlog which also states
the problem and time at the beginning of the file.
2021-07-08 14:53:15 +02:00
Julian Brost
9ebd812da5
Use boost::stacktrace instead of custom implementation in Windows SEH filter
2021-07-08 14:53:15 +02:00
Julian Brost
b5017b78d7
Run termination handler for uncaught C++ exceptions on Windows
...
On Windows, the termination handler is executed for uncaught C++
exceptions unless a SEH unhandled exception filter is also set. In this
case, this filter has to explicitly chain the default filter to keep
this behavior.
2021-07-08 14:53:15 +02:00
Alexander Aleksandrovič Klimov
088860474c
Merge pull request #8877 from Icinga/bugfix/fixed-dt-end-notify-212
...
Checkable::NotifyDowntimeEnd(): don't send Downtime end notification unless triggered
2021-07-07 23:55:17 +02:00
Alexander Aleksandrovič Klimov
fac7e5043e
Merge pull request #8879 from Icinga/feature/scheduleddowntime-change-remove-downtimes-212
...
On ScheduledDowntime change: remove downtimes created before change
2021-07-07 22:36:40 +02:00
Alexander Aleksandrovič Klimov
8550c01d3c
Merge pull request #8886 from Icinga/feature/windows-build-scripts-32-bit-212
...
Windows build scripts: allow setting BITS=32 to use 32 bit dependency paths by default
2021-07-07 19:23:39 +02:00
Alexander Aleksandrovič Klimov
09b56242f3
Merge pull request #8885 from Icinga/feature/openssl111k-212
...
Bump OpenSSL to 1.1.1k
2021-07-07 19:23:16 +02:00
Alexander A. Klimov
0cca93543c
Checkable::NotifyDowntimeEnd(): don't send Downtime end notification unless triggered
...
... for fixed Downtimes as well.
2021-07-07 15:42:20 +02:00
Alexander A. Klimov
2bcd249efb
On ScheduledDowntime change: remove future downtimes created before change
...
refs #8309
2021-07-07 15:42:18 +02:00
Alexander A. Klimov
c7ad5f6e2e
On ScheduledDowntime change: ignore downtimes created before change
...
... while creating new downtimes.
refs #8309
2021-07-07 15:42:18 +02:00
Alexander A. Klimov
2dcba12765
Introduce Downtime#config_owner_hash
...
refs #8309
2021-07-07 15:42:18 +02:00
Alexander A. Klimov
c203716ff3
ScheduledDowntime: ignore not related Downtimes while creating Downtimes
2021-07-07 15:42:18 +02:00
Alexander A. Klimov
13d3d18a7f
Downtime#Start(): trigger fixed downtimes immediately instead of waiting for the timer
...
... not to cause e.g. notifications if a problem occurs
between the downtime start time and the timer routine.
2021-07-07 15:31:46 +02:00