Branch data Line data Source code
1 : : // Copyright (c) 2009-2010 Satoshi Nakamoto
2 : : // Copyright (c) 2009-2021 The Bitcoin Core developers
3 : : // Distributed under the MIT software license, see the accompanying
4 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 : :
6 : : #ifndef BITCOIN_NODE_WARNINGS_H
7 : : #define BITCOIN_NODE_WARNINGS_H
8 : :
9 : : #include <sync.h>
10 : : #include <util/translation.h>
11 : :
12 : : #include <map>
13 : : #include <variant>
14 : : #include <vector>
15 : :
16 : : class UniValue;
17 : :
18 : : namespace kernel {
19 : : enum class Warning;
20 : : } // namespace kernel
21 : :
22 : : namespace node {
23 : : enum class Warning {
24 : : CLOCK_OUT_OF_SYNC,
25 : : PRE_RELEASE_TEST_BUILD,
26 : : FATAL_INTERNAL_ERROR,
27 : : };
28 : :
29 : : /**
30 : : * @class Warnings
31 : : * @brief Manages warning messages within a node.
32 : : *
33 : : * The Warnings class provides mechanisms to set, unset, and retrieve
34 : : * warning messages. It updates the GUI when warnings are changed.
35 : : *
36 : : * This class is designed to be non-copyable to ensure warnings
37 : : * are managed centrally.
38 : : */
39 : 3654 : class Warnings
40 : : {
41 : : typedef std::variant<kernel::Warning, node::Warning> warning_type;
42 : :
43 : : mutable Mutex m_mutex;
44 : : std::map<warning_type, bilingual_str> m_warnings GUARDED_BY(m_mutex);
45 : :
46 : : public:
47 : : Warnings();
48 : : //! A warnings instance should always be passed by reference, never copied.
49 : : Warnings(const Warnings&) = delete;
50 : : Warnings& operator=(const Warnings&) = delete;
51 : : /**
52 : : * @brief Set a warning message. If a warning with the specified
53 : : * `id` is already active, false is returned and the new
54 : : * warning is ignored. If `id` does not yet exist, the
55 : : * warning is set, the UI is updated, and true is returned.
56 : : *
57 : : * @param[in] id Unique identifier of the warning.
58 : : * @param[in] message Warning message to be shown.
59 : : *
60 : : * @returns true if the warning was indeed set (i.e. there is no
61 : : * active warning with this `id`), otherwise false.
62 : : */
63 : : bool Set(warning_type id, bilingual_str message) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex);
64 : : /**
65 : : * @brief Unset a warning message. If a warning with the specified
66 : : * `id` is active, it is unset, the UI is updated, and true
67 : : * is returned. Otherwise, no warning is unset and false is
68 : : * returned.
69 : : *
70 : : * @param[in] id Unique identifier of the warning.
71 : : *
72 : : * @returns true if the warning was indeed unset (i.e. there is an
73 : : * active warning with this `id`), otherwise false.
74 : : */
75 : : bool Unset(warning_type id) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex);
76 : : /** Return potential problems detected by the node, sorted by the
77 : : * warning_type id */
78 : : std::vector<bilingual_str> GetMessages() const EXCLUSIVE_LOCKS_REQUIRED(!m_mutex);
79 : : };
80 : :
81 : : /**
82 : : * RPC helper function that wraps warnings.GetMessages().
83 : : *
84 : : * Returns a UniValue::VSTR with the latest warning if use_deprecated is
85 : : * set to true, or a UniValue::VARR with all warnings otherwise.
86 : : */
87 : : UniValue GetWarningsForRpc(const Warnings& warnings, bool use_deprecated);
88 : : } // namespace node
89 : :
90 : : #endif // BITCOIN_NODE_WARNINGS_H
|