|             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          810 : 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
         |