Bitcoin Core  31.0.0
P2P Digital Currency
pcp.h
Go to the documentation of this file.
1 // Copyright (c) 2024-present The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or https://www.opensource.org/licenses/mit-license.php.
4 
5 #ifndef BITCOIN_COMMON_PCP_H
6 #define BITCOIN_COMMON_PCP_H
7 
8 #include <netaddress.h>
9 #include <util/threadinterrupt.h>
10 
11 #include <variant>
12 
13 // RFC6886 NAT-PMP and RFC6887 Port Control Protocol (PCP) implementation.
14 // NAT-PMP and PCP use network byte order (big-endian).
15 
17 constexpr size_t PCP_MAP_NONCE_SIZE = 12;
18 
20 typedef std::array<uint8_t, PCP_MAP_NONCE_SIZE> PCPMappingNonce;
21 
23 enum class MappingError {
27  NO_RESOURCES,
28 };
29 
31 struct MappingResult {
32  MappingResult(uint8_t version, const CService &internal_in, const CService &external_in, uint32_t lifetime_in):
33  version(version), internal(internal_in), external(external_in), lifetime(lifetime_in) {}
35  uint8_t version;
37  CService internal;
41  uint32_t lifetime;
42 
44  std::string ToString() const;
45 };
46 
55 std::variant<MappingResult, MappingError> NATPMPRequestPortMap(const CNetAddr &gateway, uint16_t port, uint32_t lifetime, CThreadInterrupt& interrupt, int num_tries = 3, std::chrono::milliseconds timeout_per_try = std::chrono::milliseconds(1000));
56 
67 std::variant<MappingResult, MappingError> PCPRequestPortMap(const PCPMappingNonce &nonce, const CNetAddr &gateway, const CNetAddr &bind, uint16_t port, uint32_t lifetime, CThreadInterrupt& interrupt, int num_tries = 3, std::chrono::milliseconds timeout_per_try = std::chrono::milliseconds(1000));
68 
69 #endif // BITCOIN_COMMON_PCP_H
std::array< uint8_t, PCP_MAP_NONCE_SIZE > PCPMappingNonce
PCP mapping nonce. Arbitrary data chosen by the client to identify a mapping.
Definition: pcp.h:20
uint32_t lifetime
Granted lifetime of binding (seconds).
Definition: pcp.h:41
unsigned int nonce
Definition: miner_tests.cpp:82
Any kind of network-level error.
Any kind of protocol-level error, except unsupported version or no resources.
A combination of a network address (CNetAddr) and a (TCP) port.
Definition: netaddress.h:529
MappingError
Unsuccessful response to a port mapping.
Definition: pcp.h:23
CService internal
Internal host:port.
Definition: pcp.h:37
MappingResult(uint8_t version, const CService &internal_in, const CService &external_in, uint32_t lifetime_in)
Definition: pcp.h:32
A helper class for interruptible sleeps.
Network address.
Definition: netaddress.h:112
uint8_t version
Protocol version, one of NATPMP_VERSION or PCP_VERSION.
Definition: pcp.h:35
std::variant< MappingResult, MappingError > PCPRequestPortMap(const PCPMappingNonce &nonce, const CNetAddr &gateway, const CNetAddr &bind, uint16_t port, uint32_t lifetime, CThreadInterrupt &interrupt, int num_tries=3, std::chrono::milliseconds timeout_per_try=std::chrono::milliseconds(1000))
Try to open a port using RFC 6887 Port Control Protocol (PCP).
Definition: pcp.cpp:406
std::string ToString() const
Format mapping as string for logging.
Definition: pcp.cpp:544
Unsupported protocol version.
No resources available (port probably already mapped).
CService external
External host:port.
Definition: pcp.h:39
Successful response to a port mapping.
Definition: pcp.h:31
constexpr size_t PCP_MAP_NONCE_SIZE
Mapping nonce size in bytes (see RFC6887 section 11.1).
Definition: pcp.h:17
std::variant< MappingResult, MappingError > NATPMPRequestPortMap(const CNetAddr &gateway, uint16_t port, uint32_t lifetime, CThreadInterrupt &interrupt, int num_tries=3, std::chrono::milliseconds timeout_per_try=std::chrono::milliseconds(1000))
Try to open a port using RFC 6886 NAT-PMP.
Definition: pcp.cpp:282