2014-01-09 06:44:08 +01:00
|
|
|
// Copyright (c) 2013-2014 Conformal Systems LLC.
|
2013-05-08 21:31:00 +02:00
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package btcwire
|
|
|
|
|
|
|
|
import (
|
2014-01-03 15:32:43 +01:00
|
|
|
"fmt"
|
2013-05-08 21:31:00 +02:00
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2013-07-27 23:31:47 +02:00
|
|
|
// MainPort is the port used by default on the main network.
|
|
|
|
MainPort = "8333"
|
|
|
|
|
|
|
|
// TestNetPort is the port used by default on the test network (version
|
|
|
|
// 3).
|
|
|
|
TestNetPort = "18333"
|
|
|
|
|
|
|
|
// RegressionTestPort is the port used by default on the regression test
|
|
|
|
// network.
|
|
|
|
RegressionTestPort = "18444"
|
|
|
|
|
|
|
|
// ProtocolVersion is the latest protocol version this package supports.
|
2013-11-12 06:12:23 +01:00
|
|
|
ProtocolVersion uint32 = 70002
|
2013-07-27 23:31:47 +02:00
|
|
|
|
2013-05-08 21:31:00 +02:00
|
|
|
// MultipleAddressVersion is the protocol version which added multiple
|
|
|
|
// addresses per message (pver >= MultipleAddressVersion).
|
|
|
|
MultipleAddressVersion uint32 = 209
|
|
|
|
|
|
|
|
// NetAddressTimeVersion is the protocol version which added the
|
|
|
|
// timestamp field (pver >= NetAddressTimeVersion).
|
|
|
|
NetAddressTimeVersion uint32 = 31402
|
|
|
|
|
|
|
|
// BIP0031Version is the protocol version AFTER which a pong message
|
|
|
|
// and nonce field in ping were added (pver > BIP0031Version).
|
|
|
|
BIP0031Version uint32 = 60000
|
|
|
|
|
|
|
|
// BIP0035Version is the protocol version which added the mempool
|
|
|
|
// message (pver >= BIP0035Version).
|
|
|
|
BIP0035Version uint32 = 60002
|
2013-05-10 07:54:56 +02:00
|
|
|
|
|
|
|
// BIP0037Version is the protocol version which added new connection
|
|
|
|
// bloom filtering related messages and extended the version message
|
|
|
|
// with a relay flag (pver >= BIP0037Version).
|
|
|
|
BIP0037Version uint32 = 70001
|
2013-11-12 06:12:07 +01:00
|
|
|
|
|
|
|
// RejectVersion is the protocol version which added a new reject
|
|
|
|
// message.
|
|
|
|
RejectVersion uint32 = 70002
|
2013-05-08 21:31:00 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// ServiceFlag identifies services supported by a bitcoin peer.
|
|
|
|
type ServiceFlag uint64
|
|
|
|
|
|
|
|
const (
|
2013-07-27 23:31:47 +02:00
|
|
|
// SFNodeNetwork is a flag used to indicate a peer is a full node.
|
2013-05-08 21:31:00 +02:00
|
|
|
SFNodeNetwork ServiceFlag = 1 << iota
|
|
|
|
)
|
|
|
|
|
|
|
|
// Map of service flags back to their constant names for pretty printing.
|
|
|
|
var sfStrings = map[ServiceFlag]string{
|
|
|
|
SFNodeNetwork: "SFNodeNetwork",
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns the ServiceFlag in human-readable form.
|
|
|
|
func (f ServiceFlag) String() string {
|
|
|
|
// No flags are set.
|
|
|
|
if f == 0 {
|
|
|
|
return "0x0"
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add individual bit flags.
|
|
|
|
s := ""
|
|
|
|
for flag, name := range sfStrings {
|
|
|
|
if f&flag == flag {
|
|
|
|
s += name + "|"
|
|
|
|
f -= flag
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add any remaining flags which aren't accounted for as hex.
|
|
|
|
s = strings.TrimRight(s, "|")
|
|
|
|
if f != 0 {
|
|
|
|
s += "|0x" + strconv.FormatUint(uint64(f), 16)
|
|
|
|
}
|
|
|
|
s = strings.TrimLeft(s, "|")
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
// BitcoinNet represents which bitcoin network a message belongs to.
|
|
|
|
type BitcoinNet uint32
|
|
|
|
|
|
|
|
// Constants used to indicate the message bitcoin network. They can also be
|
|
|
|
// used to seek to the next message when a stream's state is unknown, but
|
|
|
|
// this package does not provide that functionality since it's generally a
|
|
|
|
// better idea to simply disconnect clients that are misbehaving over TCP.
|
|
|
|
const (
|
2013-07-27 23:18:13 +02:00
|
|
|
// MainNet represents the main bitcoin network.
|
2013-07-26 02:04:58 +02:00
|
|
|
MainNet BitcoinNet = 0xd9b4bef9
|
|
|
|
|
2013-07-27 23:18:13 +02:00
|
|
|
// TestNet represents the regression test network.
|
2013-07-26 02:04:58 +02:00
|
|
|
TestNet BitcoinNet = 0xdab5bffa
|
|
|
|
|
2013-07-27 23:18:13 +02:00
|
|
|
// TestNet3 represents the test network (version 3).
|
2013-05-08 21:31:00 +02:00
|
|
|
TestNet3 BitcoinNet = 0x0709110b
|
|
|
|
)
|
2014-01-03 15:32:43 +01:00
|
|
|
|
|
|
|
// bnStrings is a map of bitcoin networks back to their constant names for
|
|
|
|
// pretty printing.
|
|
|
|
var bnStrings = map[BitcoinNet]string{
|
|
|
|
MainNet: "MainNet",
|
|
|
|
TestNet: "TestNet",
|
|
|
|
TestNet3: "TestNet3",
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns the BitcoinNet in human-readable form.
|
|
|
|
func (n BitcoinNet) String() string {
|
|
|
|
if s, ok := bnStrings[n]; ok {
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
return fmt.Sprintf("Unknown BitcoinNet (%d)", uint32(n))
|
|
|
|
}
|