12111 Commits

Author SHA1 Message Date
Julian Brost
fe9c825a18 Merge branch 'support/2.12' into jbrost/feature/improve-crashlog-212 2021-07-06 15:38:28 +02:00
Alexander Aleksandrovič Klimov
9898ccf63f
Merge pull request #8862 from Icinga/feature/gha-windows-212
GitHub actions: build Windows
2021-07-06 10:24:32 +02:00
Julian Brost
bf1c33c5c2 Stacktrace test: try to prevent inlining even harder
- Explicitly disable optimizations for MSVC
- Make stack_test_func_a bigger
2021-07-05 16:19:00 +02:00
Julian Brost
b814a7f8ac Add comments to stack trace formatter and test case 2021-07-05 16:19:00 +02:00
Julian Brost
9ef143cd1e Compile with -D_GNU_SOURCE
Needed by `boost::stacktrace` for `_Unwind_Backtrace()`.
2021-07-05 16:19:00 +02:00
Julian Brost
2d7f1d9c4f 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-05 16:19:00 +02:00
Julian Brost
c5ac3840be Add a test case for the stack trace formatter 2021-07-05 16:19:00 +02:00
Julian Brost
32a1642b0b 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-05 16:19:00 +02:00
Julian Brost
93dbde9a07 Crash handlers: use more compact string representation 2021-07-05 16:19:00 +02:00
Julian Brost
31781a81bb 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-05 16:19:00 +02:00
Julian Brost
861028191d 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-05 16:19:00 +02:00
Julian Brost
f21e449cab docs: mention use of boost::stacktrace 2021-07-05 16:19:00 +02:00
Julian Brost
3bdbcea5ad 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-05 16:19:00 +02:00
Julian Brost
0d0192fa08 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-05 16:19:00 +02:00
Julian Brost
06a5906b20 Add documentation for cast_exception function 2021-07-05 16:19:00 +02:00
Julian Brost
3418b6a863 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-05 16:19:00 +02:00
Julian Brost
ca92129756 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-05 16:19:00 +02:00
Julian Brost
c0577d865c Print details in uncaught SEH exception handler 2021-07-05 16:19:00 +02:00
Julian Brost
8b242df453 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-05 16:19:00 +02:00
Julian Brost
4cd2b9f0a0 Use boost::stacktrace instead of custom implementation in Windows SEH filter 2021-07-05 16:19:00 +02:00
Julian Brost
87631dde25 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-05 16:19:00 +02:00
Alexander A. Klimov
e94044f8aa GitHub actions: build Windows 2021-07-05 14:19:09 +02:00
Alexander A. Klimov
4a0d1a0c96 Don't use Appveyor 2021-07-05 14:18:51 +02:00
Alexander A. Klimov
045c439940 Docs: provide shorter and batch-ier instructions on how to setup a Windows dev env 2021-07-05 14:18:34 +02:00
Julian Brost
0a918c463a Update AppVeyor Config to use Visual Studio 2019 2021-07-05 14:18:15 +02:00
Julian Brost
954da11a96 Update Windows build scripts for Visual Studio 2019
$env:CMAKE_GENERATOR_PLATFORM is only used in configure-dev.ps1 but now
is also required in configure.ps1 to allow the build pipeline to be
upgraded to Visual Studio 2019.

Additionally bump the versions in paths for Boost and OpenSSL.
2021-07-05 14:17:55 +02:00
Julian Brost
1d714a887c
Merge pull request #8861 from Icinga/bugfix/gha-cancel-212
GitHub actions: auto-cancel previous jobs for the same PR
2021-07-05 11:33:58 +02:00
Alexander A. Klimov
6b5130e913 GitHub actions: auto-cancel previous jobs for the same PR
https://github.com/marketplace/actions/auto-cancellation-running-action
2021-07-02 18:12:21 +02:00
Julian Brost
685cc5c155
Merge pull request #8801 from Icinga/feature/release-v2.12.4
Version update and changelog for v2.12.4
v2.12.4
2021-05-27 09:26:57 +02:00
Alexander Aleksandrovič Klimov
b7ff749c77
Merge pull request #8809 from Icinga/bugfix/mysql-one-transaction-for-programstatus-2.12
IDO: Use own transaction for program status and make sure InternalNewTransaction() gets executed
2021-05-26 17:50:29 +02:00
Alexander Aleksandrovič Klimov
f2cd24b437
Merge pull request #8771 from Icinga/bugfix/retry-rename-on-windows-2.12
Retry file rename operations on Windows for some errors (2.12)
2021-05-26 17:50:22 +02:00
Alexander Aleksandrovič Klimov
6ceba45739
Merge pull request #8777 from Icinga/bugfix/runworker-exceptions-2.12
Improve handling of exceptions thrown by RunWorker (2.12)
2021-05-26 16:44:54 +02:00
Julian Brost
c1cee03833 Version update and changelog for v2.12.4 2021-05-26 16:09:30 +02:00
Alexander Aleksandrovič Klimov
8f0b7910b9
Merge pull request #8775 from Icinga/bugfix/problem-notification-at-downtime-end-2.12
Send problem notifications after downtime end for checkables in child zones (2.12)
2021-05-26 11:04:56 +02:00
Alexander Aleksandrovič Klimov
bb4356cc83
Merge pull request #8782 from Icinga/bugfix/concurent-notification-send-and-delete-2.12
Fix crash when notifications are sent while the notification object is deleted (2.12)
2021-05-26 11:01:55 +02:00
Alexander Aleksandrovič Klimov
c18cb90f27
Merge pull request #8785 from Icinga/bugfix/concurrent-schedule-downtime-delete-host-2.12
Fix null pointer dereferences when deleting objects while scheduling downtimes (2.12)
2021-05-26 11:00:03 +02:00
Alexander Aleksandrovič Klimov
204bac296e
Merge pull request #8787 from Icinga/bugfix/api-put-object-deletion-212-7726
ConfigObjectUtility#CreateObject(): check config objects for duplicates
2021-05-26 10:44:38 +02:00
Alexander Aleksandrovič Klimov
195ae0a2ce
Merge pull request #8808 from Icinga/bugfix/reminder-notification-after-timeperiod-with-interval-0-2.12
Make sure not to send reminder notification, if problem notification has been suppressed by TimePeriod
2021-05-26 10:44:21 +02:00
Noah Hilverling
24cbd0685b IDO-MySQL: Make sure InternalNewTransaction() and FinishAsyncQueries() get executed during high load 2021-05-25 17:22:26 +02:00
Noah Hilverling
7d8be5ee69 IDO: Use own transaction for programstatus 2021-05-25 17:13:21 +02:00
Noah Hilverling
511f6bd6b5 Notifications: Make sure not to send reminder notification, if problem notification has been suppressed 2021-05-25 16:59:38 +02:00
Alexander A. Klimov
817fe3fcac ConfigObjectUtility#CreateObject(): check config objects for duplicates
... not to delete already existing objects during a trial of re-creation.

refs #7726
2021-05-25 16:29:58 +02:00
Julian Brost
35c9c656a0 AddDowntime: return Downtime::Ptr instead of String containing the name
At numerous places in the code, something like this is performed:

    String name = Downtime::AddDowntime(...);
    Downtime::Ptr downtime = Downtime::GetByName(name);

However, `downtime` can be a `nullptr` after this as it is possible that
the downtime is deleted in between.

This commit changes the return type of `Downtime::AddDowntime` to return
a Downtime::Ptr instead of the full name of the downtime. `AddDowntime`
performs the very same `GetByName()` operation internally, but handles
the `nullptr` case correctly and throws an exception.
2021-05-25 15:59:55 +02:00
Julian Brost
0cef85cf83 Properly handle service downtime referencing a deleted host
Only two out of three cases were handled properly by the code: host
downtimes referencing a deleted host and service downtimes referencing a
deleted service worked fine. However, if a service downtime references a
deleted host, `Host::GetByName()` returns `nullptr` which isn't
accounted for. Use `Service::GetByNamePair()` instead as this performs a
check for the host being null internally.
2021-05-25 15:59:55 +02:00
Julian Brost
30b7a1e65b Use reference-counted pointer in notification callback
`this` could be deleted after `Notification::BeginExecuteNotification`
exited and before `Notification::ExecuteNotificationHelper` finished.
This is fixed by constructing a `Notification::Ptr` and operate on that
one as it is properly reference-counted.
2021-05-25 15:59:29 +02:00
Julian Brost
c4e58477a0 Try to log useful information for exceptions thrown by RunWorker 2021-05-25 15:58:53 +02:00
Julian Brost
b98a96258c Catch exceptions thrown by RunWorker on Windows
The same is already done on other platforms in line 529.
2021-05-25 15:58:53 +02:00
Julian Brost
ddafaa0add Only handle event::SetSuppressed{Notifications,NotificationTypes} within the local zone
Note that even when passing `nullptr` as target zone to `RelayMessage()`, the
cluster message will still be sent to the parent zone. These incoming messages
will now be rejected by the parent nodes. At the moment, there's no way to only
send within the local zone.
2021-05-25 15:58:17 +02:00
Julian Brost
d109dfcb78 Retry file rename operations on Windows for some errors 2021-05-25 15:57:41 +02:00
Alexander Aleksandrovič Klimov
da1dd05dca
Merge pull request #8792 from Icinga/bugfix/212boost174
Support Boost 1.74
2021-05-25 15:51:13 +02:00