1
0
Fork 0
mirror of https://github.com/ACINQ/eclair.git synced 2025-02-23 14:40:34 +01:00
Commit graph

1655 commits

Author SHA1 Message Date
Pierre-Marie Padiou
e62adf2dea
Made using/storing/sending consistent (#1082)
We know can now do `goto(STATE) using DATA storing() sending msg1 msg2`.
2019-07-24 10:03:44 +02:00
Bastien Teinturier
93d9369f90
Variable-length onion payloads (#976)
Add support for variable-length onion payloads at the Sphinx (cryptographic) layer.
This is currently unused as we keep using the legacy format by default (this will be changed in a later commit).
This commit also refactors quite heavily the Sphinx file.
2019-07-23 12:22:29 +02:00
Bastien Teinturier
189b11e9bf
Handle fulfill not acked upstream (#1079)
When we want to fulfill an HTLC but the upstream peer is unresponsive, we must close the channel if we get too close to the HTLC timeout on their side.
Otherwise we risk an on-chain race condition between our HTLC success transaction and their HTLC timeout transaction, which could result in a loss of funds.
2019-07-23 11:11:40 +02:00
Pierre-Marie Padiou
00df431472
Replace traits by bitfield for ChannelVersion (#1073)
We now store the channel version on a 8B bitfield prefixed by `0x01`
2019-07-15 13:11:20 +02:00
Bastien Teinturier
62946a0426
Switch varint codec to big-endian. (#1075) 2019-07-15 11:55:40 +02:00
Pierre-Marie Padiou
c1a7b4fe50
Added a channel version to Commitments object (#1059)
In a backward-compatible way, by using the fact that the first object of
a legacy `Commitments` was a public key, starting from 0x02 or 0x03.
2019-07-12 13:36:33 +02:00
Bastien Teinturier
1621e393dd
TLV improvements and full spec compatibility (#1069)
This PR adds support for truncated integers as defined in the spec.
The test vectors are updated to include all test vectors from rusty's spec PR.
It also provides many changes to the tlv and tlv stream classes:

- The tlv trait doesn't need a type field, the codec should handle that
- A TLV stream should be scoped to a specific subtrait of tlv
- Stream validation is done inside the codec instead of the tlv stream: it makes it more convenient for application layers to create tlv streams and manipulate them
2019-07-11 17:25:14 +02:00
araspitzu
5f4a2ebf3e
Wrap all routes in toStrictEntity (#1032)
* Wrap all routes in toStrictEntity
2019-07-09 16:49:55 +02:00
Fabrice Drouin
7d89dd01a1
Electrum: update checkpoints (#1067)
Checkpoints generated on July 9th 2019
2019-07-09 16:00:18 +02:00
Pierre-Marie Padiou
e5c5a4cfbc
Handle unknown fields in network announcements (#1047)
All the data contained in `node_announcement`, `channel_announcement`
and `channel_update` is to be included in the signature, including
unknown trailing fields. We were ignoring them, causing signature
verification to fail when there was unknown fields.

In the case of `channel_update` there is a backward compatibility issue
to handle, because when persisting channel data in state `NORMAL`, we
used to store the `channel_update` followed by other data, and without
prefixing it with size information.

To work around that we use the same trick as before, based on an
additional discriminator codec.
2019-07-08 17:14:01 +02:00
Bastien Teinturier
22548733e6
Add a few improvements to tlv. (#1065)
Hide some internals (tlvFallback, generictlv codecs).
Add a length-prefixed tlv stream codec.
2019-07-08 10:05:18 +02:00
araspitzu
9afb26e09c
Add eclair-cli to eclair's docker image (#1063)
* Add eclair-cli to eclair's docker image

* Add instructions to use eclair-cli inside the docker container
2019-07-05 09:10:06 +02:00
Pierre-Marie Padiou
683294ee57
Use a RelayResult class instead of an Either (#1064)
It is functionnaly the same but it's cleaner and removes the need for
tuples in the success case.
2019-07-04 14:06:05 +02:00
Fabrice Drouin
bbe07c2c42
Set version to 0.3.2-SNAPSHOT (#1062) 2019-07-04 10:00:44 +02:00
Fabrice Drouin
6906ecb403
Set version to v0.3.1 (#1061) 2019-07-03 17:23:12 +02:00
araspitzu
20ea9d0e1d
Reject payments for expired invoices (#1057)
* Reject payments for expired invoices
2019-07-03 15:52:03 +02:00
Pierre-Marie Padiou
32145e8d6a
Connect immediately on restart, then wait (#1040)
* connect immediately on restart, then wait

This is to allow herd effect when we restart the app and have numerous
peers.

Also removed the unnecessary transition and cleaned up delay
computation.

* always reconnect immediately when disconnected

Whether we go to this state from startup, or after getting disconnected.

It makes the transition logic simpler, and the potential herd effect at
startup is inevitable anyway since our peers will try to reconnect too.

* add randomization when reconnecting

* randomize delay for first reconnection attempt after startup

* make some parameters configurable
2019-07-03 13:15:20 +02:00
Pierre-Marie Padiou
f724efaa76
Close the channel if the funding tx never confirms (#1034)
If we are fundee and after 5 days the funding isn't even in the mempool,
then we give up waiting and consider the channel closed. Note that if
the funding tx stays unconfirmed forever we won't give up waiting.

If we are funder, we never give up until the funding tx is double spent,
and we periodically republish it.

This applies to states `WAIT_FOR_FUNDING_CONFIRMED` and `CLOSING` (and
also `OFFLINE`/`SYNCING` when underlying state is
`WAIT_FOR_FUNDING_CONFIRMED`).

Also, added a generic way of passing context to `ElectrumClient`
requests/responses.

Fixes #1029.
2019-07-03 12:00:00 +02:00
araspitzu
667444cd0e
Check 'initialblockdownload' from bitcoind during startup (#1058) 2019-07-02 17:31:53 +02:00
Bastien Teinturier
1cc14aeda3
Add TLV and TLV stream codec support (#1045)
TLV (tag-length-value) types and TLV streams have been defined in the following spec PR: https://github.com/lightningnetwork/lightning-rfc/pull/607

New Lightning Messages should use TLV extensively instead of ad-hoc per-message encoding. This also allows ignoring unknown odd TLV types, which lets implementers safely test new features on mainnet without impacting legacy nodes. It also allows type re-use which speeds up new features development.

Also cleaned-up and refactored common codecs.
2019-07-02 11:53:14 +02:00
Anton Kumaigorodski
c4f07e8742 Add more data to usablebalances API method (#1053)
Now it additionally returns remote `nodeId` and `shortChannelId` for each channel. Also negative balances are represented as `0`s.
2019-07-02 11:20:02 +02:00
Pierre-Marie Padiou
5e923b6857
Make Bitcoin Core bind on localhost in tests (#1056)
* minor fixes

* fixed javadoc

* make bitcoind only bind on localhost for tests
2019-07-02 10:22:34 +02:00
Pierre-Marie Padiou
48cb8644fa
Added more memory for scoverage (#1050)
In order to fix the stack overflow errors related to scoverage.
2019-07-02 10:06:57 +02:00
araspitzu
94a526cc83
Update link for recommended JDK (#1054) 2019-07-01 09:31:37 +02:00
Anton Kumaigorodski
a35d50d4c8 Add balances API method (#962)
Currently balances can be obtained from `channels` call but this requires a lot of work on caller side and also some specific knowledge (reserves, commit tx fee, in-flight payments), so this new `balances` endpoint only returns a correct balance info for each channel.
2019-06-26 12:05:51 +02:00
araspitzu
de50cc437e Remove old service and related docs (#1046) 2019-06-24 17:46:55 +02:00
Pierre-Marie Padiou
316ba02ff8
Ack unhandled lightning messages (#1042)
In the event when we receive an unexpected message, the `Peer` was just logging a warning and not sending an `Ack` to the `TransportHandler`. This resulted in a stuck connection, because no more data was read on the connection.

Fixes #1037.
2019-06-20 11:40:01 +02:00
Pierre-Marie Padiou
38696b56e4
Minor fixes (#1043)
* fixed javadoc

* make bitcoind only bind on localhost for tests
2019-06-19 11:36:30 +02:00
Bastien Teinturier
a53145a6da
Electrum: add data to TxIdFromPosResponse. (#1038)
To make the response usable, we need to copy the request input (block height and transaction position).
2019-06-17 12:10:10 +02:00
Anton Kumaigorodski
cb1196cf95 Correctly decode requests without multipliers (#1020)
Since MAX_PAYMENT_AMOUNT has been removed we may now get payment requests without multiplier which means a whole bitcoin is requested.
2019-06-14 15:01:10 +02:00
Pierre-Marie Padiou
a3563e38bb
Removed cached codec (#1036)
It turns out that performance gains of the cached codec are not that
great, and they come at a cost of significant pressure on the GC. In
other words: premature optimization.

When removed, the heap usage becomes very stable, which is much better
than hypothetical performance gains.

Fixes #1031.
2019-06-14 14:04:15 +02:00
Bastien Teinturier
b4adff2dc4 Electrum: add id_from_pos (#1035)
This allows getting a transaction id from a short channel id.
2019-06-14 13:25:37 +02:00
Fabrice Drouin
31022ceca5
Use compact encoding for signatures (64 bytes) instead of DER (#1014)
* use 64B representation instead of DER for sigs

It is more compact, and as an added bonus it frees us from the
completely unrelated Bitcoin-specific `0x01` trailing sig hash.

Note that we already used the 64B representation for storage everywhere,
except in `ChannelCodecs.htlcTxAndSigsCodec`, which required a backward
compatibility codec. Added a nonreg test for this.

* Use updated secp256k1 JNI bindings

* Replace scalar with private key and point with public key

We now use the simplified/unified design proposed in bitcoin-lib where:
- there are no more specific types for scalar/point
- private and public keys are compressed unless explicitly requested

* Generate and use 32 bytes seeds (and not 33)

We used serialized random private keys which were represented a 33 bytes (with a 01 suffix).
Using random 32 bytes values is more consistent.
We must make sure that upgraded apps that already have a 33 bytes seed will still generate the same secrets, which is why LocalKeyManager still uses the 01 suffix when needed
2019-06-14 11:52:01 +02:00
araspitzu
199d6041c5 Output txid and serialized tx in transaction json serializer (#1033) 2019-06-13 18:10:09 +02:00
Pierre-Marie Padiou
db334380b3
Clean pending htlcs db (#1027)
We store `CMD_FULFILL_HTLC`/`CMD_FAIL_HTLC`/`CMD_FAIL_MALFORMED_HTLC` in
a database (see `CommandBuffer`) because we don't want to lose
preimages, or to forget to fail incoming htlcs, which would lead to
unwanted channel closings.

But we currently only clean up this database on success, and because of
the way our watcher works, in a scenario where a downstream channel has
gone to the blockchain, it may send several times the same command. Only
the first one will be acked and cleaned up by the upstream channel,
causing the remaining commands to stay forever in the "pending relay
db".

With this change we clean up the commands when they fail too.

We also clean up the pending relay db on startup.
2019-06-13 18:08:34 +02:00
Pierre-Marie Padiou
849b6bd22b
Smarter restore logic for closing channels (#1015)
If the closing type is known:
 - there is no need to watch the funding tx because it has already
 been spent and the spending tx has already reached min_depth
 - there is no need to attempt to publish transactions for other
 type of closes.

* differentiate current/next remote close

We can still match on the trait `RemoteClose` if we don't need that
level of precision.
2019-06-12 12:29:31 +02:00
araspitzu
818199e8f4
Peer reconnection address from node announcements (#1009)
* Use node announcements as fallback to load peer addresses during startup

* Add NetworkDb.getNode to retrieve a node_announcement by nodeId

* When connecting to a peer use node_announcement as fallback for its IP address

* Support connection to peer via pubKey

* Increase finite max of exponential backoff time to 1h.

* Add peer disconnect API call
2019-06-11 17:39:52 +02:00
araspitzu
9087ceeb5f Add feeThresholdSat and maxFeePct parameters to payments API (#1023) 2019-06-11 15:34:47 +02:00
Pierre-Marie Padiou
f180e54b03
Close channel if funding tx times out (#1016)
This only happens when we are fundee. We *could* have some funds at
stake if there was a non-zero `push_msat`, but we already allows 5 days
for the funding tx to confirm so the best option is probably to forget
about the channel.
2019-06-11 14:31:23 +02:00
Pierre-Marie Padiou
b33c9ecaac
Smarter relay logic (#1011)
When relaying a payment, we look in the onion to find the next
`shortChannelId`. But we may choose a different channel (to the same
node), because the requested channel may not have enough balance, of for
some other reasons, as permitted by the spec.

Currently we limit ourselves to only two attempts: one with a
"preferred" channel, and one with the originally requested channel if is
different from the preferred one. This has drawbacks, because if we have
multiple channels to the same node, we may not be able to relay a
payment if the "preferred" channel is currently unavailable (e.g.
because of an htlc in-flight value that is too high).

We now retry as many times as there are available channels, in our order
of preference, and if all fail, then we return a failure message for the
originally requested channel.
2019-06-03 19:10:14 +02:00
Fabrice Drouin
cd78c9ecdd
Electrum: update server list (#1022)
* Electrum: update server list

* Electrum: set client name to 3.3.6
2019-06-03 13:45:51 +02:00
Dominique
3e46475f9f Initialize global feerate with default from conf (#1019)
`Globals.feeratePerKB` is an atomic reference initialized to `null` and
is asynchronously set by the fee provider only once it's ready. This
means that it is possible to retrieve a null object from feeratePerKB,
scenario that must be handled separately to prevent any issues.

This commit now initialize `Globals.feeratePerKB` with the default
values set in the configuration file. This makes sure that the
feerate is always set to a meaningful value.
2019-06-03 09:44:06 +02:00
Pierre-Marie Padiou
c4b7ade038
Removed PaymentRequest.MAX_AMOUNT (#1018)
It was obsole since
068b0bccf9.

Note that we use a signed long, but it doesn't matter since 2^64
milli-satoshis is greater than the total number of bitcoins.
2019-05-28 14:14:17 +02:00
Pierre-Marie Padiou
b82d7211cc
Set handleCommandError to WARN (#1012)
Those are not fatal errors for channels.
2019-05-27 17:33:20 +02:00
Fabrice Drouin
648f57276a Electrum: consistently retrieve wallet transactions (#1010)
* Electrum: update mainnet and testnet servers list

* Electrum: request missing history transactions on reconnect

Upon connection/reconnection, ask for transactions that are included in our history but
which we don't have and don't have a pending request for.

* Electrum: add disconnect/reconnect tests

Simulate disconnections and check that wallet eventually gets it history and transactions.
2019-05-23 16:36:54 +02:00
Pierre-Marie Padiou
92e2d21eab
Make htlc-reaper a top-level actor (#1013)
The way we handle requests to `Switchboard` assume that all children are `Peer`s. This led the `peer` API request to timeout.
2019-05-21 17:36:29 +02:00
araspitzu
101bcd7c50
Send to route (#952)
* Add /sendtoroute API and functionality

* Do not use extractor pattern in PaymentLifecycle::SendPaymentToRoute

* /sendtoroute: support route parameter as comma separated list

* Add test for 'sendtoroute' in EclairImplSpec
2019-05-20 15:20:53 +02:00
araspitzu
cfaa5508eb
Increase Service and EclairImpl test coverage (#1004)
* /payinvoice: assert the override amount is being used in the invoice

* /updaterelayfee: assert the values passed through the API call are forwarder to EclairImpl

* 'receive' API: test for fallback address usage and parameters passing

* 'close' API: test for parameters handling

* 'networkFees': test for default parameters

* Add test dependency mockito-scala, rewrite a test using the mock framework

* Factor out query filter parsing in EclairImpl, Add test for networkFees/audit/allinvoice

* Move getDefaultTimestampFilters in companion object, group together EclairImpl-scoped classes
2019-05-20 14:22:09 +02:00
araspitzu
80340c1fbf
API: optionally use a user supplied preimage when creating invoices (#965)
* Add support for custom preimage in /createinvoice API

* Add test for using a custom preimage in payment request
2019-05-17 17:11:38 +02:00
Pierre-Marie Padiou
8718959164
Improved test coverage of io package (#996)
* improved test coverage of `NodeURI`

* improved test coverage of `Peer`
2019-05-10 19:53:50 +02:00