You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
3.1 KiB
92 lines
3.1 KiB
// Copyright (c) 2013-2014 The btcsuite developers |
|
// Use of this source code is governed by an ISC |
|
// license that can be found in the LICENSE file. |
|
|
|
package main |
|
|
|
import ( |
|
"github.com/btcsuite/btcd/chaincfg" |
|
"github.com/btcsuite/btcd/wire" |
|
) |
|
|
|
// 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 { |
|
*chaincfg.Params |
|
rpcPort string |
|
dnsSeeds []string |
|
} |
|
|
|
// mainNetParams contains parameters specific to the main network |
|
// (wire.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: &chaincfg.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 (wire.TestNet). NOTE: The RPC port is intentionally different |
|
// than the reference implementation - see the mainNetParams comment for |
|
// details. |
|
var regressionNetParams = params{ |
|
Params: &chaincfg.RegressionNetParams, |
|
rpcPort: "18334", |
|
dnsSeeds: []string{}, |
|
} |
|
|
|
// testNet3Params contains parameters specific to the test network (version 3) |
|
// (wire.TestNet3). NOTE: The RPC port is intentionally different than the |
|
// reference implementation - see the mainNetParams comment for details. |
|
var testNet3Params = params{ |
|
Params: &chaincfg.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 |
|
// (wire.SimNet). |
|
var simNetParams = params{ |
|
Params: &chaincfg.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 |
|
// chaincfg parameters. This function can be used to override this directory |
|
// name as "testnet" when the passed active network matches wire.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(chainParams *params) string { |
|
switch chainParams.Net { |
|
case wire.TestNet3: |
|
return "testnet" |
|
default: |
|
return chainParams.Name |
|
} |
|
}
|
|
|