Skip to content

Commit 628ec8e

Browse files
committed
lint: format README.md
Adds spaces around headings and sections. See https://github.com/DavidAnson/markdownlint/blob/v0.31.1/doc/md022.md
1 parent 630ce88 commit 628ec8e

File tree

1 file changed

+55
-40
lines changed

1 file changed

+55
-40
lines changed

README.md

+55-40
Original file line numberDiff line numberDiff line change
@@ -1,42 +1,49 @@
11
# SimLN
22

3-
SimLN is a simulation tool that can be used to generate realistic
4-
payment activity on any lightning network topology. It is intentionally
5-
environment-agnostic so that it can be used across many environments -
6-
from integration tests to public signets.
3+
SimLN is a simulation tool that can be used to generate realistic
4+
payment activity on any lightning network topology. It is intentionally
5+
environment-agnostic so that it can be used across many environments -
6+
from integration tests to public signets.
77

8-
This tool is intended to serve developers who are familiar with
8+
This tool is intended to serve developers who are familiar with
99
lightning network development. It may be useful to you if you are:
10-
* A protocol developer looking to test proposals.
10+
11+
* A protocol developer looking to test proposals.
1112
* An application developer load-testing your application.
12-
* A signet operator interested in a hands-off way to run an active node.
13+
* A signet operator interested in a hands-off way to run an active node.
1314
* A researcher generating synthetic data for a target topology.
1415

1516
## Pre-Requisites
16-
SimLN requires you to "bring your own network" to generate activity
17+
18+
SimLN requires you to "bring your own network" to generate activity
1719
on. You will need:
18-
* A [lightning network](#lightning-environments) connected with any
20+
21+
* A [lightning network](#lightning-environments) connected with any
1922
topology of channels.
2023
* Access to execute commands on _at least_ one node in the network.
2124
* Rust compiler [installed](https://www.rust-lang.org/tools/install).
2225

2326
## LN Implementation Support
24-
* LND ✅
25-
* CLN ✅
27+
28+
* LND ✅
29+
* CLN ✅
2630
* Eclair 🏗️
2731
* LDK-node 🏗️
2832

2933
See our [tracking issue](https://github.com/bitcoin-dev-project/sim-ln/issues/26)
3034
for updates on implementation support (contributions welcome!).
3135

3236
## Getting Started
33-
Clone the repo:
37+
38+
Clone the repo:
39+
3440
```
3541
git clone https://github.com/bitcoin-dev-project/sim-ln
3642
cd sim-ln
3743
```
3844

39-
Install the CLI:
45+
Install the CLI:
46+
4047
```
4148
cargo install --locked --path sim-cli/
4249
```
@@ -50,9 +57,10 @@ sim-cli
5057
Run `sim-cli -h` to see configuration options available. See [setup instructions](#simulation-file-setup) for details on configuring the simulation file.
5158

5259
### Simulation File Setup
53-
The simulator requires access details for a set of `nodes` that you
54-
have permission to execute commands on. Note that the current version
55-
of the simulator uses keysend to execute payments, which must be
60+
61+
The simulator requires access details for a set of `nodes` that you
62+
have permission to execute commands on. Note that the current version
63+
of the simulator uses keysend to execute payments, which must be
5664
enabled in LND using `--accept-keysend` (for CLN node it is enabled by default).
5765

5866
The required access details will depend on the node implementation. For LND, the following
@@ -82,17 +90,18 @@ Whereas for CLN nodes, the following information is required:
8290
**Note that node addresses must be declare with HTTPS transport, i.e. <https://ip-or-domain:port>**
8391

8492
Payment activity can be simulated in two different ways:
85-
* Random activity: generate random activity on the `nodes` provided,
93+
94+
* Random activity: generate random activity on the `nodes` provided,
8695
using the graph topology to determine payment frequency and size.
87-
* Defined activity: provide descriptions of specific payments that
96+
* Defined activity: provide descriptions of specific payments that
8897
you would like the generator to execute.
8998

9099
### Setup - Random Activity
91100

92-
To run the simulator with random activity generation, you just need to
93-
provide a set of nodes and the simulator will generate activity based
94-
on the topology of the underlying graph. Note that payments will only
95-
be sent between the `nodes` that are provided so that liquidity does
101+
To run the simulator with random activity generation, you just need to
102+
provide a set of nodes and the simulator will generate activity based
103+
on the topology of the underlying graph. Note that payments will only
104+
be sent between the `nodes` that are provided so that liquidity does
96105
not "drain" from the simulation.
97106

98107
```
@@ -116,35 +125,39 @@ not "drain" from the simulation.
116125
```
117126

118127
Nodes can be identified by an arbitrary string ("Alice", "CLN1", etc) or
119-
by their node public key. If a valid public key is provided it *must*
128+
by their node public key. If a valid public key is provided it _must_
120129
match the public key reported by the node.
121130

122-
There are a few cli flags that can be used to toggle the characteristics
123-
of the random activity that is generated:
124-
* `--expected-payment-amount`: the approximate average amount that
131+
There are a few cli flags that can be used to toggle the characteristics
132+
of the random activity that is generated:
133+
134+
* `--expected-payment-amount`: the approximate average amount that
125135
will be sent by nodes, randomness will be introduced such that larger
126136
nodes send a wider variety of payment sizes around this expectation.
127-
* `--capacity-multiplier`: the number of times over that each node in
137+
* `--capacity-multiplier`: the number of times over that each node in
128138
the network sends their capacity in a calendar month, for example:
129-
* `capacity-multiplier=2` means that each node sends double their
139+
* `capacity-multiplier=2` means that each node sends double their
130140
capacity in a month.
131-
* `capacity-multiplier=0.5` means that each node sends half their
141+
* `capacity-multiplier=0.5` means that each node sends half their
132142
capacity in a month.
133143

134144
### Setup - Defined Activity
135-
If you would like SimLN to generate a specific payments between source
136-
and destination nodes, you can provide `activity` descriptions of the
137-
source, destination, frequency and amount for payments that you'd like
138-
to execute. Note that `source` nodes *must* be contained in `nodes`,
139-
but destination nodes can be any public node in the network (though
145+
146+
If you would like SimLN to generate a specific payments between source
147+
and destination nodes, you can provide `activity` descriptions of the
148+
source, destination, frequency and amount for payments that you'd like
149+
to execute. Note that `source` nodes _must_ be contained in `nodes`,
150+
but destination nodes can be any public node in the network (though
140151
this may result in liquidity draining over time).
141152

142153
The example simulation file below sets up the following simulation:
154+
143155
* Connect to `Alice` running LND to generate activity.
144156
* Connect to `Bob` running CLN to generate activity.
145157
* Dispatch 2000 msat payments from `Alice` to `Carol` every 1 seconds.
146158
* Dispatch 140000 msat payments from `Bob` to `Alice` every 50 seconds.
147159
* Dispatch 1000 msat payments from `Bob` to `Dave` every 2 seconds.
160+
148161
```
149162
{
150163
"nodes": [
@@ -187,9 +200,9 @@ The example simulation file below sets up the following simulation:
187200

188201
**Note that node addresses must be declare with HTTPS transport, i.e <https://ip-or-domain>**
189202

190-
Nodes can be identified by their public key or an id string (as
191-
described above). Activity sources and destinations may reference the
192-
`id` defined in `nodes`, but destinations that are not listed in `nodes`
203+
Nodes can be identified by their public key or an id string (as
204+
described above). Activity sources and destinations may reference the
205+
`id` defined in `nodes`, but destinations that are not listed in `nodes`
193206
*must* provide a valid public key.
194207

195208
### Simulation Output
@@ -201,10 +214,12 @@ Run `sim-cli -h` for details on data directory (`--data-dir`) and other options
201214
which affect how simulation outputs are persisted
202215

203216
## Lightning Environments
217+
204218
If you're looking to get started with local lightning development, we
205-
recommend [polar](https://lightningpolar.com/). For larger deployments,
206-
see the [Scaling Lightning](https://github.com/scaling-lightning/scaling-lightning)
219+
recommend [polar](https://lightningpolar.com/). For larger deployments,
220+
see the [Scaling Lightning](https://github.com/scaling-lightning/scaling-lightning)
207221
project.
208222

209223
## Docker
210-
If you want to run the cli in a containerized environment, see the docker set up docs [here](./docker/README.md)
224+
225+
If you want to run the cli in a containerized environment, see the docker set up docs [here](./docker/README.md)

0 commit comments

Comments
 (0)