2016-08-13 01:29:38 +03:00
|
|
|
package btcwallet
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
|
2017-06-08 03:01:17 +03:00
|
|
|
"github.com/lightningnetwork/lnd/lnwallet"
|
2016-08-13 01:29:38 +03:00
|
|
|
"github.com/roasbeef/btcd/chaincfg"
|
|
|
|
"github.com/roasbeef/btcd/wire"
|
|
|
|
"github.com/roasbeef/btcutil"
|
2017-02-24 16:31:38 +03:00
|
|
|
|
2017-06-06 05:44:54 +03:00
|
|
|
"github.com/roasbeef/btcwallet/chain"
|
|
|
|
|
2017-02-24 16:32:33 +03:00
|
|
|
// This is required to register bdb as a valid walletdb driver. In the
|
|
|
|
// init function of the package, it registers itself. The import is used
|
|
|
|
// to activate the side effects w/o actually binding the package name to
|
|
|
|
// a file-level variable.
|
2016-08-13 01:29:38 +03:00
|
|
|
_ "github.com/roasbeef/btcwallet/walletdb/bdb"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
lnwalletHomeDir = btcutil.AppDataDir("lnwallet", false)
|
|
|
|
defaultDataDir = lnwalletHomeDir
|
|
|
|
|
|
|
|
defaultLogFilename = "lnwallet.log"
|
|
|
|
defaultLogDirname = "logs"
|
|
|
|
defaultLogDir = filepath.Join(lnwalletHomeDir, defaultLogDirname)
|
|
|
|
|
|
|
|
btcdHomeDir = btcutil.AppDataDir("btcd", false)
|
|
|
|
btcdHomedirCAFile = filepath.Join(btcdHomeDir, "rpc.cert")
|
|
|
|
defaultRPCKeyFile = filepath.Join(lnwalletHomeDir, "rpc.key")
|
|
|
|
defaultRPCCertFile = filepath.Join(lnwalletHomeDir, "rpc.cert")
|
|
|
|
|
|
|
|
// defaultPubPassphrase is the default public wallet passphrase which is
|
|
|
|
// used when the user indicates they do not want additional protection
|
|
|
|
// provided by having all public data in the wallet encrypted by a
|
|
|
|
// passphrase only known to them.
|
|
|
|
defaultPubPassphrase = []byte("public")
|
|
|
|
|
|
|
|
walletDbName = "lnwallet.db"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Config is a struct which houses configuration paramters which modify the
|
|
|
|
// instance of BtcWallet generated by the New() function.
|
|
|
|
type Config struct {
|
|
|
|
// DataDir is the name of the directory where the wallet's persistent
|
|
|
|
// state should be sotred.
|
|
|
|
DataDir string
|
|
|
|
|
|
|
|
// LogDir is the name of the directory which should be used to store
|
|
|
|
// generated log files.
|
|
|
|
LogDir string
|
|
|
|
|
2017-05-25 03:34:03 +03:00
|
|
|
// PrivatePass is the private password to the underlying btcwallet
|
|
|
|
// instance. Without this, the wallet cannot be decrypted and operated.
|
|
|
|
PrivatePass []byte
|
2016-08-13 01:29:38 +03:00
|
|
|
|
2017-05-25 03:34:03 +03:00
|
|
|
// PublicPass is the optional public password to btcwallet. This is
|
|
|
|
// optionally used to encrypt public material such as public keys and
|
|
|
|
// scripts.
|
|
|
|
PublicPass []byte
|
2016-08-13 01:29:38 +03:00
|
|
|
|
2017-05-25 03:34:03 +03:00
|
|
|
// HdSeed is an optional seed to feed into the wallet. If this is
|
|
|
|
// unspecified, a new seed will be generated.
|
|
|
|
HdSeed []byte
|
2016-08-13 01:29:38 +03:00
|
|
|
|
2017-05-25 03:34:03 +03:00
|
|
|
// ChainSource is the primary chain interface. This is used to operate
|
|
|
|
// the wallet and do things such as rescanning, sending transactions,
|
|
|
|
// notifications for received funds, etc.
|
|
|
|
ChainSource chain.Interface
|
2016-08-13 01:29:38 +03:00
|
|
|
|
2017-06-08 03:01:17 +03:00
|
|
|
// FeeEstimator is an instance of the fee estimator interface which
|
|
|
|
// will be used by the wallet to dynamically set transaction fees when
|
|
|
|
// crafting transactions.
|
|
|
|
FeeEstimator lnwallet.FeeEstimator
|
|
|
|
|
2017-05-25 03:34:03 +03:00
|
|
|
// NetParams is the net parameters for the target chain.
|
2016-08-13 01:29:38 +03:00
|
|
|
NetParams *chaincfg.Params
|
|
|
|
}
|
|
|
|
|
2017-10-12 12:07:58 +03:00
|
|
|
// NetworkDir returns the directory name of a network directory to hold wallet
|
2016-08-13 01:29:38 +03:00
|
|
|
// files.
|
2017-10-12 12:07:58 +03:00
|
|
|
func NetworkDir(dataDir string, chainParams *chaincfg.Params) string {
|
2016-08-13 01:29:38 +03:00
|
|
|
netname := chainParams.Name
|
|
|
|
|
|
|
|
// For now, we must always name the testnet data directory as "testnet"
|
|
|
|
// and not "testnet3" or any other version, as the chaincfg testnet3
|
2017-06-08 03:01:17 +03:00
|
|
|
// parameters will likely be switched to being named "testnet3" in the
|
2016-08-13 01:29:38 +03:00
|
|
|
// future. This is done to future proof that change, and an upgrade
|
|
|
|
// plan to move the testnet3 data directory can be worked out later.
|
|
|
|
if chainParams.Net == wire.TestNet3 {
|
|
|
|
netname = "testnet"
|
|
|
|
}
|
|
|
|
|
|
|
|
return filepath.Join(dataDir, netname)
|
|
|
|
}
|