premiere-libtorrent/include/libtorrent/alert.hpp

352 lines
13 KiB
C++

/*
Copyright (c) 2003-2018, Arvid Norberg, Daniel Wallin
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in
the documentation and/or other materials provided with the distribution.
* Neither the name of the author nor the names of its
contributors may be used to endorse or promote products derived
from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef TORRENT_ALERT_HPP_INCLUDED
#define TORRENT_ALERT_HPP_INCLUDED
#include <string>
// OVERVIEW
//
// The pop_alerts() function on session is the main interface for retrieving
// alerts (warnings, messages and errors from libtorrent). If no alerts have
// been posted by libtorrent pop_alerts() will return an empty list.
//
// By default, only errors are reported. settings_pack::alert_mask can be
// used to specify which kinds of events should be reported. The alert mask is
// a combination of the alert_category_t flags in the alert class.
//
// Every alert belongs to one or more category. There is a cost associated with
// posting alerts. Only alerts that belong to an enabled category are
// posted. Setting the alert bitmask to 0 will disable all alerts (except those
// that are non-discardable). Alerts that are responses to API calls such as
// save_resume_data() and post_session_stats() are non-discardable and will be
// posted even if their category is disabled.
//
// There are other alert base classes that some alerts derive from, all the
// alerts that are generated for a specific torrent are derived from
// torrent_alert, and tracker events derive from tracker_alert.
//
// Alerts returned by pop_alerts() are only valid until the next call to
// pop_alerts(). You may not copy an alert object to access it after the next
// call to pop_alerts(). Internal members of alerts also become invalid once
// pop_alerts() is called again.
#include "libtorrent/time.hpp"
#include "libtorrent/config.hpp"
#include "libtorrent/flags.hpp"
namespace libtorrent {
// bitmask type used to define alert categories. Categories can be enabled
// and disabled by the settings_pack::alert_mask setting. Constants are defined
// in the lt::alert_category namespace
using alert_category_t = flags::bitfield_flag<std::uint32_t, struct alert_category_tag>;
namespace alert_category {
// Enables alerts that report an error. This includes:
//
// * tracker errors
// * tracker warnings
// * file errors
// * resume data failures
// * web seed errors
// * .torrent files errors
// * listen socket errors
// * port mapping errors
constexpr alert_category_t error = 0_bit;
// Enables alerts when peers send invalid requests, get banned or
// snubbed.
constexpr alert_category_t peer = 1_bit;
// Enables alerts for port mapping events. For NAT-PMP and UPnP.
constexpr alert_category_t port_mapping = 2_bit;
// Enables alerts for events related to the storage. File errors and
// synchronization events for moving the storage, renaming files etc.
constexpr alert_category_t storage = 3_bit;
// Enables all tracker events. Includes announcing to trackers,
// receiving responses, warnings and errors.
constexpr alert_category_t tracker = 4_bit;
// Low level alerts for when peers are connected and disconnected.
constexpr alert_category_t connect = 5_bit;
// Enables alerts for when a torrent or the session changes state.
constexpr alert_category_t status = 6_bit;
// Alerts when a peer is blocked by the ip blocker or port blocker.
constexpr alert_category_t ip_block = 8_bit;
// Alerts when some limit is reached that might limit the download
// or upload rate.
constexpr alert_category_t performance_warning = 9_bit;
// Alerts on events in the DHT node. For incoming searches or
// bootstrapping being done etc.
constexpr alert_category_t dht = 10_bit;
// If you enable these alerts, you will receive a stats_alert
// approximately once every second, for every active torrent.
// These alerts contain all statistics counters for the interval since
// the lasts stats alert.
constexpr alert_category_t stats = 11_bit;
// Enables debug logging alerts. These are available unless libtorrent
// was built with logging disabled (``TORRENT_DISABLE_LOGGING``). The
// alerts being posted are log_alert and are session wide.
constexpr alert_category_t session_log = 13_bit;
// Enables debug logging alerts for torrents. These are available
// unless libtorrent was built with logging disabled
// (``TORRENT_DISABLE_LOGGING``). The alerts being posted are
// torrent_log_alert and are torrent wide debug events.
constexpr alert_category_t torrent_log = 14_bit;
// Enables debug logging alerts for peers. These are available unless
// libtorrent was built with logging disabled
// (``TORRENT_DISABLE_LOGGING``). The alerts being posted are
// peer_log_alert and low-level peer events and messages.
constexpr alert_category_t peer_log = 15_bit;
// enables the incoming_request_alert.
constexpr alert_category_t incoming_request = 16_bit;
// enables dht_log_alert, debug logging for the DHT
constexpr alert_category_t dht_log = 17_bit;
// enable events from pure dht operations not related to torrents
constexpr alert_category_t dht_operation = 18_bit;
// enables port mapping log events. This log is useful
// for debugging the UPnP or NAT-PMP implementation
constexpr alert_category_t port_mapping_log = 19_bit;
// enables verbose logging from the piece picker.
constexpr alert_category_t picker_log = 20_bit;
// alerts when files complete downloading
constexpr alert_category_t file_progress = 21_bit;
// alerts when pieces complete downloading or fail hash check
constexpr alert_category_t piece_progress = 22_bit;
// alerts when we upload blocks to other peers
constexpr alert_category_t upload = 23_bit;
// alerts on individual blocks being requested, downloading, finished,
// rejected, time-out and cancelled. This is likely to post alerts at a
// high rate.
constexpr alert_category_t block_progress = 24_bit;
// The full bitmask, representing all available categories.
//
// since the enum is signed, make sure this isn't
// interpreted as -1. For instance, boost.python
// does that and fails when assigning it to an
// unsigned parameter.
constexpr alert_category_t all = alert_category_t::all();
} // namespace alert_category
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
#endif
// The ``alert`` class is the base class that specific messages are derived from.
// alert types are not copyable, and cannot be constructed by the client. The
// pointers returned by libtorrent are short lived (the details are described
// under session_handle::pop_alerts())
class TORRENT_EXPORT alert
{
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
public:
// hidden
alert(alert const& rhs) = delete;
alert& operator=(alert const&) = delete;
alert(alert&& rhs) noexcept = default;
#if TORRENT_ABI_VERSION == 1
// only here for backwards compatibility
enum TORRENT_DEPRECATED_ENUM severity_t { debug, info, warning, critical, fatal, none };
using category_t = alert_category_t;
#endif
static constexpr alert_category_t error_notification = 0_bit;
static constexpr alert_category_t peer_notification = 1_bit;
static constexpr alert_category_t port_mapping_notification = 2_bit;
static constexpr alert_category_t storage_notification = 3_bit;
static constexpr alert_category_t tracker_notification = 4_bit;
static constexpr alert_category_t connect_notification = 5_bit;
#if TORRENT_ABI_VERSION == 1
static constexpr alert_category_t TORRENT_DEPRECATED_MEMBER debug_notification = connect_notification;
#endif
static constexpr alert_category_t status_notification = 6_bit;
#if TORRENT_ABI_VERSION == 1
static constexpr alert_category_t TORRENT_DEPRECATED_MEMBER progress_notification = 7_bit;
#endif
static constexpr alert_category_t ip_block_notification = 8_bit;
static constexpr alert_category_t performance_warning = 9_bit;
static constexpr alert_category_t dht_notification = 10_bit;
static constexpr alert_category_t stats_notification = 11_bit;
#if TORRENT_ABI_VERSION == 1
static constexpr alert_category_t TORRENT_DEPRECATED_MEMBER rss_notification = 12_bit;
#endif
static constexpr alert_category_t session_log_notification = 13_bit;
static constexpr alert_category_t torrent_log_notification = 14_bit;
static constexpr alert_category_t peer_log_notification = 15_bit;
static constexpr alert_category_t incoming_request_notification = 16_bit;
static constexpr alert_category_t dht_log_notification = 17_bit;
static constexpr alert_category_t dht_operation_notification = 18_bit;
static constexpr alert_category_t port_mapping_log_notification = 19_bit;
static constexpr alert_category_t picker_log_notification = 20_bit;
static constexpr alert_category_t file_progress_notification = 21_bit;
static constexpr alert_category_t piece_progress_notification = 22_bit;
static constexpr alert_category_t upload_notification = 23_bit;
static constexpr alert_category_t block_progress_notification = 24_bit;
static constexpr alert_category_t all_categories = alert_category_t::all();
// hidden
alert();
// hidden
virtual ~alert();
// a timestamp is automatically created in the constructor
time_point timestamp() const;
// returns an integer that is unique to this alert type. It can be
// compared against a specific alert by querying a static constant called ``alert_type``
// in the alert. It can be used to determine the run-time type of an alert* in
// order to cast to that alert type and access specific members.
//
// e.g:
//
// .. code:: c++
//
// std::vector<alert*> alerts;
// ses.pop_alerts(&alerts);
// for (alert* i : alerts) {
// switch (a->type()) {
//
// case read_piece_alert::alert_type:
// {
// auto* p = static_cast<read_piece_alert*>(a);
// if (p->ec) {
// // read_piece failed
// break;
// }
// // use p
// break;
// }
// case file_renamed_alert::alert_type:
// {
// // etc...
// }
// }
// }
virtual int type() const noexcept = 0;
// returns a string literal describing the type of the alert. It does
// not include any information that might be bundled with the alert.
virtual char const* what() const noexcept = 0;
// generate a string describing the alert and the information bundled
// with it. This is mainly intended for debug and development use. It is not suitable
// to use this for applications that may be localized. Instead, handle each alert
// type individually and extract and render the information from the alert depending
// on the locale.
virtual std::string message() const = 0;
// returns a bitmask specifying which categories this alert belong to.
virtual alert_category_t category() const noexcept = 0;
#if TORRENT_ABI_VERSION == 1
#include "libtorrent/aux_/disable_warnings_push.hpp"
// determines whether or not an alert is allowed to be discarded
// when the alert queue is full. There are a few alerts which may not be discarded,
// since they would break the user contract, such as save_resume_data_alert.
TORRENT_DEPRECATED
bool discardable() const { return discardable_impl(); }
TORRENT_DEPRECATED
severity_t severity() const { return warning; }
protected:
virtual bool discardable_impl() const { return true; }
#include "libtorrent/aux_/disable_warnings_pop.hpp"
#endif // TORRENT_ABI_VERSION
private:
time_point const m_timestamp;
};
// When you get an alert, you can use ``alert_cast<>`` to attempt to cast the
// pointer to a specific alert type, in order to query it for more
// information.
//
// .. note::
// ``alert_cast<>`` can only cast to an exact alert type, not a base class
template <class T> T* alert_cast(alert* a)
{
static_assert(std::is_base_of<alert, T>::value
, "alert_cast<> can only be used with alert types (deriving from lt::alert)");
if (a == nullptr) return nullptr;
if (a->type() == T::alert_type) return static_cast<T*>(a);
return nullptr;
}
template <class T> T const* alert_cast(alert const* a)
{
static_assert(std::is_base_of<alert, T>::value
, "alert_cast<> can only be used with alert types (deriving from lt::alert)");
if (a == nullptr) return nullptr;
if (a->type() == T::alert_type) return static_cast<T const*>(a);
return nullptr;
}
} // namespace libtorrent
#endif // TORRENT_ALERT_HPP_INCLUDED