2007-12-03 07:03:16 +01:00
|
|
|
/*
|
|
|
|
|
2016-01-18 00:57:46 +01:00
|
|
|
Copyright (c) 2007-2016, Arvid Norberg
|
2007-12-03 07:03:16 +01:00
|
|
|
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_MAGNET_URI_HPP_INCLUDED
|
|
|
|
#define TORRENT_MAGNET_URI_HPP_INCLUDED
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include "libtorrent/config.hpp"
|
|
|
|
#include "libtorrent/torrent_handle.hpp"
|
2009-11-26 06:45:43 +01:00
|
|
|
#include "libtorrent/add_torrent_params.hpp"
|
2017-03-31 04:55:54 +02:00
|
|
|
#include "libtorrent/string_view.hpp"
|
2007-12-03 07:03:16 +01:00
|
|
|
|
2017-04-12 19:00:57 +02:00
|
|
|
namespace libtorrent {
|
|
|
|
|
2007-12-03 07:03:16 +01:00
|
|
|
struct torrent_handle;
|
2011-02-21 06:24:41 +01:00
|
|
|
class session;
|
2007-12-03 07:03:16 +01:00
|
|
|
|
2013-08-08 03:03:54 +02:00
|
|
|
// Generates a magnet URI from the specified torrent. If the torrent
|
|
|
|
// handle is invalid, an empty string is returned.
|
2016-10-22 17:47:24 +02:00
|
|
|
//
|
2013-08-11 08:04:24 +02:00
|
|
|
// For more information about magnet links, see magnet-links_.
|
2016-10-22 17:47:24 +02:00
|
|
|
//
|
2017-04-13 15:48:01 +02:00
|
|
|
TORRENT_EXPORT std::string make_magnet_uri(torrent_handle const& handle);
|
|
|
|
TORRENT_EXPORT std::string make_magnet_uri(torrent_info const& info);
|
2007-12-03 07:03:16 +01:00
|
|
|
|
2008-08-03 17:14:08 +02:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
2012-03-08 10:54:44 +01:00
|
|
|
#ifndef BOOST_NO_EXCEPTIONS
|
2008-08-03 17:14:08 +02:00
|
|
|
// deprecated in 0.14
|
2017-04-13 15:48:01 +02:00
|
|
|
TORRENT_DEPRECATED_EXPORT
|
|
|
|
torrent_handle add_magnet_uri(session& ses, std::string const& uri
|
2009-10-26 02:29:39 +01:00
|
|
|
, std::string const& save_path
|
2007-12-03 07:03:16 +01:00
|
|
|
, storage_mode_t storage_mode = storage_mode_sparse
|
|
|
|
, bool paused = false
|
|
|
|
, storage_constructor_type sc = default_storage_constructor
|
2017-09-28 10:11:20 +02:00
|
|
|
, void* userdata = nullptr);
|
2008-08-03 17:14:08 +02:00
|
|
|
|
2012-03-08 10:54:44 +01:00
|
|
|
// deprecated in 0.16. Instead, pass in the magnet link as add_torrent_params::url
|
2017-04-13 15:48:01 +02:00
|
|
|
TORRENT_DEPRECATED_EXPORT
|
|
|
|
torrent_handle add_magnet_uri(session& ses, std::string const& uri
|
2017-03-26 20:54:16 +02:00
|
|
|
, add_torrent_params p);
|
2009-02-26 08:09:56 +01:00
|
|
|
#endif
|
|
|
|
|
2012-03-08 10:54:44 +01:00
|
|
|
// deprecated in 0.16. Instead, pass in the magnet link as add_torrent_params::url
|
2017-04-13 15:48:01 +02:00
|
|
|
TORRENT_DEPRECATED_EXPORT
|
|
|
|
torrent_handle add_magnet_uri(session& ses, std::string const& uri
|
2017-03-26 20:54:16 +02:00
|
|
|
, add_torrent_params p, error_code& ec);
|
2012-03-08 10:54:44 +01:00
|
|
|
#endif
|
|
|
|
|
2017-12-13 17:42:55 +01:00
|
|
|
|
2013-08-08 03:03:54 +02:00
|
|
|
// This function parses out information from the magnet link and populates the
|
2017-11-05 17:11:28 +01:00
|
|
|
// add_torrent_params object. The overload that does not take an
|
|
|
|
// ``error_code`` reference will throw a system_error on error
|
2017-12-13 17:42:55 +01:00
|
|
|
// The overload taking an ``add_torrent_params`` reference will fill in the
|
|
|
|
// fields specified in the magnet URI.
|
2017-10-14 16:40:48 +02:00
|
|
|
TORRENT_EXPORT add_torrent_params parse_magnet_uri(string_view uri, error_code& ec);
|
2017-11-05 17:11:28 +01:00
|
|
|
TORRENT_EXPORT add_torrent_params parse_magnet_uri(string_view uri);
|
2017-12-13 17:42:55 +01:00
|
|
|
TORRENT_EXPORT void parse_magnet_uri(string_view uri, add_torrent_params& p, error_code& ec);
|
2007-12-03 07:03:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|