92 lines
3 KiB
Go
92 lines
3 KiB
Go
// Copyright (c) 2013-2014 Conformal Systems LLC.
|
|
// Use of this source code is governed by an ISC
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package main
|
|
|
|
import (
|
|
"github.com/conformal/btcnet"
|
|
"github.com/conformal/btcwire"
|
|
)
|
|
|
|
// activeNetParams is a pointer to the parameters specific to the
|
|
// currently active bitcoin network.
|
|
var activeNetParams = &mainNetParams
|
|
|
|
// params is used to group parameters for various networks such as the main
|
|
// network and test networks.
|
|
type params struct {
|
|
*btcnet.Params
|
|
rpcPort string
|
|
dnsSeeds []string
|
|
}
|
|
|
|
// mainNetParams contains parameters specific to the main network
|
|
// (btcwire.MainNet). NOTE: The RPC port is intentionally different than the
|
|
// reference implementation because btcd does not handle wallet requests. The
|
|
// separate wallet process listens on the well-known port and forwards requests
|
|
// it does not handle on to btcd. This approach allows the wallet process
|
|
// to emulate the full reference implementation RPC API.
|
|
var mainNetParams = params{
|
|
Params: &btcnet.MainNetParams,
|
|
rpcPort: "8334",
|
|
dnsSeeds: []string{
|
|
"seed.bitcoin.sipa.be",
|
|
"dnsseed.bluematt.me",
|
|
"dnsseed.bitcoin.dashjr.org",
|
|
"seed.bitcoinstats.com",
|
|
"seed.bitnodes.io",
|
|
"bitseed.xf2.org",
|
|
"seeds.bitcoin.open-nodes.org",
|
|
},
|
|
}
|
|
|
|
// regressionNetParams contains parameters specific to the regression test
|
|
// network (btcwire.TestNet). NOTE: The RPC port is intentionally different
|
|
// than the reference implementation - see the mainNetParams comment for
|
|
// details.
|
|
var regressionNetParams = params{
|
|
Params: &btcnet.RegressionNetParams,
|
|
rpcPort: "18334",
|
|
dnsSeeds: []string{},
|
|
}
|
|
|
|
// testNet3Params contains parameters specific to the test network (version 3)
|
|
// (btcwire.TestNet3). NOTE: The RPC port is intentionally different than the
|
|
// reference implementation - see the mainNetParams comment for details.
|
|
var testNet3Params = params{
|
|
Params: &btcnet.TestNet3Params,
|
|
rpcPort: "18334",
|
|
dnsSeeds: []string{
|
|
"testnet-seed.alexykot.me",
|
|
"testnet-seed.bitcoin.schildbach.de",
|
|
"testnet-seed.bitcoin.petertodd.org",
|
|
"testnet-seed.bluematt.me",
|
|
},
|
|
}
|
|
|
|
// simNetParams contains parameters specific to the simulation test network
|
|
// (btcwire.SimNet).
|
|
var simNetParams = params{
|
|
Params: &btcnet.SimNetParams,
|
|
rpcPort: "18556",
|
|
dnsSeeds: []string{}, // NOTE: There must NOT be any seeds.
|
|
}
|
|
|
|
// netName returns the name used when referring to a bitcoin network. At the
|
|
// time of writing, btcd currently places blocks for testnet version 3 in the
|
|
// data and log directory "testnet", which does not match the Name field of the
|
|
// btcnet parameters. This function can be used to override this directory name
|
|
// as "testnet" when the passed active network matches btcwire.TestNet3.
|
|
//
|
|
// A proper upgrade to move the data and log directories for this network to
|
|
// "testnet3" is planned for the future, at which point this function can be
|
|
// removed and the network parameter's name used instead.
|
|
func netName(netParams *params) string {
|
|
switch netParams.Net {
|
|
case btcwire.TestNet3:
|
|
return "testnet"
|
|
default:
|
|
return netParams.Name
|
|
}
|
|
}
|