lnd version, "hacked" to enable seedless restore from xprv + scb
Go to file
Olaoluwa Osuntokun 4002caec69
config+rpc: create new generalized dynamic sub rpc server config framework
In this commit, we add the glue infrastructure to make the sub RPC
server system work properly. Our high level goal is the following: using
only the lnrpc package (with no visibility into the sub RPC servers),
the RPC server is able to find, create, run, and manage the entire set
of present and future sub RPC servers. In order to achieve this, we use
the reflect package and build tags heavily to permit a loosely coupled
configuration parsing system for the sub RPC servers.

We start with a new `subRpcServerConfigs` struct which is _always_
present.  This struct has its own group, and will house a series of
sub-configs, one for each sub RPC server. Each sub-config is actually
gated behind a build flag, and can be used to allow users on the command
line or in the config to specify arguments related to the sub-server. If
the config isn't present, then we don't attempt to parse it at all, if
it is, then that means the RPC server has been registered, and we should
parse the contents of its config.

The `subRpcServerConfigs` struct has two main methods:
`PopulateDependancies` and `FetchConfig`. The `PopulateDependancies` is
used to dynamically locate and set the config fields for each new
sub-server. As the config may not actually have any fields (if the build
flag is off), we use the reflect pacakge to determine if things are
compiled in or not, then if so, we dynamically set each of the config
parameters. The `PopulateDependancies` method implements the
`lnrpc.SubServerConfigDispatcher` interface. Our goal is to allow sub
servers to look up their actual config in this main config struct. We
achieve this by using reflect to look up the target field _as if it were
a key in a map_. If the field is found, then we check if it has any
actual attributes (it won't if the build flag is off), if it is, then we
return it as we expect it to be populated already.
2018-11-28 20:57:05 -08:00
.github github: add GitHub issue template 2018-03-28 15:02:07 -07:00
aezeed aezeed/errors: add missing space in error message 2018-06-26 19:20:39 -07:00
autopilot Typo fix autopilot 2018-10-09 18:28:34 +02:00
brontide multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00
build build: bump version to 0.5.1 2018-11-15 19:47:13 -08:00
chainntnfs chainntnfs: dispatch conf/spend notifications after blocks 2018-10-31 09:20:22 -07:00
channeldb channeldb/migrations_test: add TestMigrateOptionalChannelCloseSummaryFields 2018-11-21 13:36:42 +01:00
cmd/lncli removes duplicated default message on queryroutes command 2018-11-12 12:03:00 -03:00
contractcourt chain_watcher: poll for commit point in case of failure 2018-11-21 10:28:57 +01:00
contrib contrib: add basic bash completion for lncli 2017-01-29 18:12:53 -08:00
discovery discovery/gossiper: send node anns when constructing full chan proof 2018-11-11 17:48:07 -08:00
docker add num_inactive_channels field to docs 2018-11-05 09:11:01 +01:00
docs docs: update docs to reflect new go modules usage and building 2018-11-28 20:13:56 -08:00
htlcswitch htlcswitch/link: remove handled TODO 2018-11-21 10:28:57 +01:00
keychain keychain: use t.Helper() instead of manually fetching the line no from the runtime 2018-08-15 16:14:02 -07:00
lncfg Merge pull request #1108 from sangaman/sever-server 2018-09-27 22:23:45 -07:00
lnpeer peer: make AddNewChannel take OpenChannel 2018-09-28 08:59:27 +02:00
lnrpc config+rpc: create new generalized dynamic sub rpc server config framework 2018-11-28 20:57:05 -08:00
lntest lntest/harness: retry ConnectPeer of chain backend still syncing 2018-11-27 10:15:00 +01:00
lnwallet Merge pull request #1937 from halseth/data-loss-protect-resending 2018-11-25 20:47:16 -06:00
lnwire htlcswitch+routing: implement expiry_too_far failure 2018-10-15 08:51:08 +02:00
macaroons macaroons/README: update noencryptwallet -> noseedbackup 2018-09-04 20:52:44 -07:00
make make/testing_flags: add LOG_TAGS, set using log envvar 2018-10-05 13:04:45 +09:00
multimutex multimutex: add new multimutex package 2018-01-24 10:26:39 +01:00
nat nat: introduce new NAT traversal package with UPnP/NAT-PMP implementations 2018-06-12 18:36:27 -07:00
queue chainntnfs+queue: move ConcurrentQueue to own package 'queue' 2018-10-18 12:38:10 -07:00
routing discovery+routing: add FetchLightningNode to ChannelGraphSource interface 2018-11-11 17:48:05 -08:00
shachain multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00
signal multi: init subsystem loggers via build pkg 2018-10-05 13:04:45 +09:00
sweep multi: modify sweeper.CreateSweepTx to accept conf target, style changes 2018-10-18 18:08:27 -07:00
ticker ticker: fix linter error 2018-08-09 22:15:41 -07:00
tor Merge pull request #1856 from maurycy/typos 2018-09-27 20:38:10 -07:00
walletunlocker walletunlocker/service: change noencryptwallet reference to noseedbackup 2018-09-04 20:52:43 -07:00
watchtower Merge pull request #2140 from cfromknecht/wtserver-move 2018-11-28 15:07:01 -08:00
zpay32 multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00
.gitignore gitignore: ignore visual studio code config 2018-09-18 07:17:44 -07:00
.travis.yml travis: force go modules support in $GOPATH, cache modules directory 2018-11-28 20:13:54 -08:00
breacharbiter_test.go main: remove disable log in testing + clean up imports 2018-10-05 13:04:45 +09:00
breacharbiter.go sweep: create new Input interface 2018-10-17 12:44:33 +02:00
chainparams.go test+lnd: update unit test mocks to adhere to new interface API's 2018-07-31 21:28:58 -07:00
chainregistry.go Revert "chainregistry: disable height hint cache" 2018-10-31 09:20:22 -07:00
chan_series.go chan_series: filter out nodes who intend to remain private 2018-10-24 19:20:01 -07:00
chancloser.go chancloser: remove error returned from unregisterChannel 2018-08-10 11:42:25 -07:00
config.go config+rpc: create new generalized dynamic sub rpc server config framework 2018-11-28 20:57:05 -08:00
doc.go add some daemon related skeleton files 2015-12-26 00:09:17 -06:00
Dockerfile Add EXPOSE directive for 9735 (p2p) & 10009 (rpc) 2018-11-14 14:12:20 +01:00
fundingmanager_test.go Merge pull request #2027 from mrwhythat/no-incoming-push-amounts-option 2018-11-02 17:08:05 -07:00
fundingmanager.go Merge pull request #2027 from mrwhythat/no-incoming-push-amounts-option 2018-11-02 17:08:05 -07:00
go.mod build: add new go.mod and go.sum files for go modules usage 2018-11-28 17:19:10 -08:00
go.sum build: add new go.mod and go.sum files for go modules usage 2018-11-28 17:19:10 -08:00
invoiceregistry.go chainntnfs+queue: move ConcurrentQueue to own package 'queue' 2018-10-18 12:38:10 -07:00
LICENSE lnd: update copyright notice 2018-11-02 14:49:36 -07:00
lnd_test.go Merge pull request #2224 from halseth/itest-timeouts 2018-11-28 08:22:46 +01:00
lnd.go Merge pull request #1786 from Roasbeef/golang-1.1 2018-10-08 13:26:07 +09:00
log.go log: register logger for new Signer RPC Service, namespace SGNR 2018-11-28 20:57:04 -08:00
logo.png README: add logo to top portion of page 2017-09-29 14:06:31 -07:00
Makefile build: update makefile to be aware of go modules, remove dep support 2018-11-28 20:13:52 -08:00
mock.go lnwallet: update to new SendOutputs signature 2018-11-10 07:57:19 +01:00
nodesigner.go multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00
nursery_store_test.go main: remove disable log in testing + clean up imports 2018-10-05 13:04:45 +09:00
nursery_store.go multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00
peer_test.go main: remove disable log in testing + clean up imports 2018-10-05 13:04:45 +09:00
peer.go peer: define resendChanSyncMsg 2018-11-21 10:28:56 +01:00
pilot.go pilot: improve error when unable to reach any of a peer's addresses 2018-08-29 02:06:03 -07:00
README.md server: properly set node pubkey within initTorController 2018-10-28 16:54:05 -07:00
release.sh release: Add ARMv6 platform to release.sh 2018-09-10 22:19:21 +02:00
rpcserver.go rpc: properly set output index in OpenChannelSync resp 2018-11-25 21:13:00 -06:00
sample-lnd.conf Merge pull request #1108 from sangaman/sever-server 2018-09-27 22:23:45 -07:00
server_test.go Improved color validation - now with fixes and a table driven test 2018-11-09 03:09:39 +01:00
server.go Improved color validation - now with fixes and a table driven test 2018-11-09 03:09:39 +01:00
subrpcserver_config.go config+rpc: create new generalized dynamic sub rpc server config framework 2018-11-28 20:57:05 -08:00
test_utils.go peer: prune persistent peer connection on zero on-disk channels 2018-09-05 18:30:45 -07:00
utxonursery_test.go utxonursery: use StaticFeeEstimator instead of mock in test 2018-11-07 15:33:36 +01:00
utxonursery.go utxonursery: remove unused TxOut serialization funcs 2018-11-07 15:33:36 +01:00
witness_beacon.go multi: sort import paths with gofmt 2018-08-02 18:20:49 -07:00

Lightning Network Daemon

Build Status MIT licensed Irc Godoc

The Lightning Network Daemon (lnd) - is a complete implementation of a Lightning Network node and currently deployed on testnet3 - the Bitcoin Test Network. lnd has several pluggable back-end chain services including btcd (a full-node), bitcoind, and neutrino (a new experimental light client). The project's codebase uses the btcsuite set of Bitcoin libraries, and also exports a large set of isolated re-usable Lightning Network related libraries within it. In the current state lnd is capable of:

  • Creating channels.
  • Closing channels.
  • Completely managing all channel states (including the exceptional ones!).
  • Maintaining a fully authenticated+validated channel graph.
  • Performing path finding within the network, passively forwarding incoming payments.
  • Sending outgoing onion-encrypted payments through the network.
  • Updating advertised fee schedules.
  • Automatic channel management (autopilot).

Lightning Network Specification Compliance

lnd fully conforms to the Lightning Network specification (BOLTs). BOLT stands for: Basis of Lightning Technology. The specifications are currently being drafted by several groups of implementers based around the world including the developers of lnd. The set of specification documents as well as our implementation of the specification are still a work-in-progress. With that said, the current status of lnd's BOLT compliance is:

  • BOLT 1: Base Protocol
  • BOLT 2: Peer Protocol for Channel Management
  • BOLT 3: Bitcoin Transaction and Script Formats
  • BOLT 4: Onion Routing Protocol
  • BOLT 5: Recommendations for On-chain Transaction Handling
  • BOLT 7: P2P Node and Channel Discovery
  • BOLT 8: Encrypted and Authenticated Transport
  • BOLT 9: Assigned Feature Flags
  • BOLT 10: DNS Bootstrap and Assisted Node Location
  • BOLT 11: Invoice Protocol for Lightning Payments

Developer Resources

The daemon has been designed to be as developer friendly as possible in order to facilitate application development on top of lnd. Two primary RPC interfaces are exported: an HTTP REST API, and a gRPC service. The exported API's are not yet stable, so be warned: they may change drastically in the near future.

An automatically generated set of documentation for the RPC APIs can be found at api.lightning.community. A set of developer resources including talks, articles, and example applications can be found at: dev.lightning.community.

Finally, we also have an active Slack where protocol developers, application developers, testers and users gather to discuss various aspects of lnd and also Lightning in general.

Installation

In order to build from source, please see the installation instructions.

Docker

To run lnd from Docker, please see the main Docker instructions

IRC

  • irc.freenode.net
  • channel #lnd
  • webchat

Security

The developers of lnd take security very seriously. The disclosure of security vulnerabilities helps us secure the health of lnd, privacy of our users, and also the health of the Lightning Network as a whole. If you find any issues regarding security or privacy, please disclose the information responsibly by sending an email to security at lightning dot engineering, preferably encrypted using our designated PGP key (91FE464CD75101DA6B6BAB60555C6465E5BCB3AF) which can be found here.

Further reading