Skip to content

Commit f1b665c

Browse files
committed
[docs] Full pass thru docs, table of contents improvements, consistency and grammar fixes, added Altcoins.md
1 parent 654aca2 commit f1b665c

13 files changed

+119
-83
lines changed

Altcoins.md

+39
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
# Altcoins
2+
3+
Support is implemented for several coins:
4+
5+
* Litecoin
6+
* BGold
7+
* BCash
8+
* Dash
9+
* Dogecoin
10+
* Feathercoin
11+
* Groestlcoin
12+
* Monacoin
13+
* Polis
14+
* UFO
15+
* Viacoin
16+
17+
## How can I add an altcoin to BTCPayServer?
18+
19+
The steps for having a coin added are:
20+
21+
1. Add support for your crypto to [NBitcoin](https://github.com/MetacoSA/NBitcoin/tree/master/NBitcoin.Altcoins), [NBxplorer](https://github.com/dgarage/NBXplorer), and [BTCPayServer](https://github.com/btcpayserver/btcpayserver). (Use examples from other coins)
22+
2. Create your own docker image ([Example for BTC](https://hub.docker.com/r/nicolasdorier/docker-bitcoin/))
23+
3. Create a docker-compose fragment ([Example for BTC](docker-compose-generator/docker-fragments/bitcoin.yml))
24+
4. Add your CryptoDefinition ([Example for BTC](docker-compose-generator/src/CryptoDefinition.cs))
25+
26+
When testing your coin, **DO NOT USE `build.sh`**, since it uses a pre-built docker image.
27+
28+
Instead, install [.NET Core 2.1 SDK](https://www.microsoft.com/net/download/windows) and run:
29+
30+
```bash
31+
BTCPAYGEN_CRYPTO1="EXAMPLE-COIN"
32+
BTCPAYGEN_SUBNAME="test"
33+
cd docker-compose-generator/src
34+
dotnet run
35+
```
36+
37+
This will generate your docker-compose in the `Generated` folder, which you can then run and test.
38+
39+
Note that BTCPayServer developers will not spend excessive time testing your image, so make sure it works.

Architecture.md

+19-26
Original file line numberDiff line numberDiff line change
@@ -1,41 +1,34 @@
1-
# How to deploy a BTCPay server instance
1+
# Architecture
22

3-
BTCPay Server is a project which ties together several applications into a coherent user experience for managing your own payment processor.
3+
BTCPayServer is a project which ties together several Bitcoin-related components into a coherent user experience for installing and managing your own payment processor.
44

5-
The minimal setup involve:
5+
![Architecture](img/Architecture.png)
6+
7+
The minimal setup involves:
68

7-
* BTCPay Server
9+
* [BTCPayServer](https://github.com/btcpayserver/btcpayserver)
810
* [NBXplorer](https://github.com/dgarage/NBXplorer) (Lightweight block explorer, responsible for tracking payments)
911
* Bitcoin Core
10-
* (Optional) Postgres
12+
* (Optional) PostgreSQL
1113

12-
By default, it uses SqlLite as database, but for production use, we advise you to use Postgres.
13-
14-
![Architecture](img/Architecture.png)
14+
By default, it uses SqlLite, but all production deployments use Postgres.
1515

16-
On top of this, if you need Lightning Network support, NBXplorer can support connection to:
16+
Additionally, if you need Lightning Network access, NBXplorer supports connections to:
1717

18-
* C-Lightning instance via unix domain socket
18+
* C-Lightning (via unix sockets)
1919
* Lightning Charge
20-
* LND via the REST Proxy
20+
* LND (via the REST interface)
2121

22-
If you want altcoin supports we support connection to the following full nodes:
22+
---
2323

24-
* BGold
25-
* Dogecoin
26-
* Feathercoin
27-
* Groestlcoin
28-
* Litecoin
29-
* Monacoin
30-
* Polis
31-
* Viacoin
24+
We provide several ways of deploying BTCPayServer, depending on whether you favor flexibility or ease-of-use.
3225

33-
Because BTCPay Server has lot's of dependencies, we provide different way of deploying depending if you favor flexibility or ease of use.
34-
From the hardest way to the easiest:
26+
From the easiest way to the hardest:
3527

36-
* [Manual deployment](ManualDeployment.md) (Downloading, building and running all the dependencies by yourself)
37-
* [Docker deployment](DockerDeployment.md) (Using a `docker-compose.yml` file which bundle all the dependencies together)
3828
* [Azure deployment](AzureDeployment.md) (Using a one-click deploy on Microsoft Azure)
39-
* [Third party hosting](Managed.md) (Having someone else manage BTCPay for you)
29+
* [Docker deployment](DockerDeployment.md) (Using a `docker-compose.yml` file which bundle all the dependencies together, in almost any environment)
30+
* [Manual deployment](ManualDeployment.md) (Downloading, building and running all the dependencies by yourself)
31+
32+
Some community members also offer [third-party hosting](ThirdPartyHosting.md) (Having someone else manage BTCPayServer for you).
4033

41-
For people who wants to try BTCPay Server and does not require lightning network payment, and are not willing to host BTCPay by themselves, we advise you to see the list of third party on [The Ultimate List of BTCPay Server Hosts and Merchants](https://bitcoinshirt.co/btcpay-stores/).
34+
Remember the **huge value** of having **direct control** of your wallet and web service; for this reason we recommend you use [Azure deployment](AzureDeployment.md) and **do the setup yourself** - it is pretty easy!

ChangeDomain.md

+19-23
Original file line numberDiff line numberDiff line change
@@ -1,65 +1,61 @@
11
# How to change the domain name of your BTCPay Server
22

3-
This article assume you know the following information:
3+
This article assumes you used either [Azure](https://github.com/btcpayserver/btcpayserver-azure) deployment or [BTCPay Docker](https://github.com/btcpayserver/btcpayserver-docker) deployment.
44

5-
* The SSH username and password of your server
6-
* That you used either [Azure](https://github.com/btcpayserver/btcpayserver-azure) deployment or [BTCPay Docker](https://github.com/btcpayserver/btcpayserver-docker) deployment.
7-
8-
Let's assume I used `Azure` deployment, on which I get an invalid certificate:
5+
Let's assume I used Azure. After initially deploying, I get an invalid certificate (this is normal during setup):
96

107
![InvalidCertificate](img/InvalidCertificate.png)
118

129
To get a valid certificate, I need to change my server address from `https://myawesomedemobtcpay.westeurope.cloudapp.azure.com/` to `https://tothemoon.btcpayserver.com/`.
1310

14-
## Pre-requisite
11+
## Setting up your DNS record
1512

16-
### Setting up your DNS record
17-
First I bought my domain name `btcpayserver.com` to a registar. (I use [gandi.net](https://gandi.net/) because they are awesome)
13+
First, I bought my domain name `btcpayserver.com` from a registar. (I use [gandi.net](https://gandi.net/) because they are awesome.)
1814

1915
Once I got the domain name, I can access it in the `Domains` menu:
2016

2117
![Gandi1](img/Gandi1.png)
2218

23-
So I click on my new domain `btcpayserver.com`, then go to the `DNS Record` menu, then I click `Add`.
19+
So I click on my new domain `btcpayserver.com`, then go to the `DNS Records` menu, then I click `Add`:
2420

2521
![Gandi2](img/Gandi2.png)
2622

27-
Here I want to make sure `tothemoon.btcpayserver.com` will resolve to the same IP address as `myawesomedemobtcpay.westeurope.cloudapp.azure.com`. We call this a `CNAME record`:
23+
Here I want to make sure `tothemoon.btcpayserver.com` will resolve to the same IP address as `myawesomedemobtcpay.westeurope.cloudapp.azure.com`. We call this a `CNAME record`.
24+
25+
So I fill out:
2826

29-
So I fill out
3027
```
3128
Type: "CNAME",
3229
Name: "tothemoon",
33-
Hostname: "myawesomedemobtcpay.westeurope.cloudapp.azure.com." DO NOT FORGET THE '.'
30+
Hostname: "myawesomedemobtcpay.westeurope.cloudapp.azure.com." !! DO NOT FORGET THE '.' !!
3431
```
35-
![Gandi3](img/Gandi3.png)
3632

37-
Then I click `Create`. Note that if you want to point to an IP address instead, you would use a type `A` record.
38-
39-
Congratulation! Now let's
33+
![Gandi3](img/Gandi3.png)
4034

41-
## From your BTCPay Server
35+
Then I click 'Create'. (Note that if you want to point directly to an IP address instead, you would use a type `A` record.)
4236

43-
First, I go to `https://myawesomedemobtcpay.westeurope.cloudapp.azure.com/server/maintenance`.
44-
I must be logged as an administrator, which is typically the first account created on the server.
37+
**Congratulations! Now let's set it up on the other side, the BTCPayServer host.**
4538

46-
I enter my SSH `Username` (by default on azure, `btcpayserver`) and `Password` I chose during the Azure Wizard setup.
39+
## From your browser
4740

48-
Then I enter my domain name `tothemoon.btcpayserver.com`, and click confirm.
41+
* Visit `https://myawesomedemobtcpay.westeurope.cloudapp.azure.com/server/maintenance`
42+
* Log in as an administrator, which is typically the first account created on the server.
43+
* Enter new hostname `tothemoon.btcpayserver.com` and click 'Confirm'.
4944

5045
![Maintenance](img/Maintenance.png)
5146

52-
I wait a bit and go to `https://tothemoon.btcpayserver.com/`, Success!
47+
I wait a bit and go to `https://tothemoon.btcpayserver.com` - Success!
5348

5449
![Maintenance2](img/Maintenance2.png)
5550

56-
## From command line
51+
## From the command line
5752

5853
I connect to my server via:
5954

6055
```bash
6156
6257
```
58+
6359
I enter the `Password` I chose during the Azure Wizard setup.
6460

6561
```bash

DockerDeployment.md

+3-3
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,9 @@
1-
# Docker-Compose setup
1+
# Docker deployment
22

33
[The minimal manual setup](ManualDeployment.md) is not good enough for production environment (no reverse proxy, no HTTPS), and is a bit complicated to deploy.
44

5-
The ideal deployment is similar to:
5+
The ideal architecture is `Docker-Compose`-driven, and looks similar to:
66

77
![Production BTCPay](https://raw.githubusercontent.com/btcpayserver/btcpayserver-docker/master/Production/Production.png)
88

9-
Please visit our [docker-compose for production environment](https://github.com/btcpayserver/btcpayserver-docker) to see how it works.
9+
Please visit [btcpayserver/btcpayserver-docker](https://github.com/btcpayserver/btcpayserver-docker) to see this production deployment and how it works.

Drupal.md

+4-1
Original file line numberDiff line numberDiff line change
@@ -10,12 +10,14 @@ The project can be found [here](https://drupal.org/project/commerce_btcpay) on d
1010

1111
## Module installation and configuration
1212

13-
### Quick walkthrough screencast:
13+
### Quick walkthrough screencast
14+
1415
[![Drupal Commerce](https://img.youtube.com/vi/XBZwyC2v48s/mqdefault.jpg)](https://youtu.be/XBZwyC2v48s "BTCPay - Drupal Commerce 2.x quick walkthrough")
1516

1617
### Quick walkthrough steps
1718

1819
#### Generate pairing code on BTCPay server
20+
1921
1. in store settings go to "**Access Tokens**"
2022
2. click on **[Create a new token]**
2123
3. **Label:** enter some label (eg. my store)
@@ -27,6 +29,7 @@ The project can be found [here](https://drupal.org/project/commerce_btcpay) on d
2729
(you will need that code below on gateway configuration, see below)
2830

2931
#### Commerce BTCPay: Installation + configuration
32+
3033
1. install module: `composer require drupal/commerce_btcpay`
3134
2. enable the module: `drush en commerce_btcpay -y`
3235
3. make sure you have configured [private file system](https://www.drupal.org/docs/8/core/modules/file/overview#content-accessing-private-files) (needed to store encrypted public+private key)

LICENSE

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
MIT License
22

3-
Copyright (c) 2017 btcpayserver
3+
Copyright (c) 2017-2018 BTCPayServer
44

55
Permission is hereby granted, free of charge, to any person obtaining a copy
66
of this software and associated documentation files (the "Software"), to deal

Local-Development.md LocalDevelopment.md

+4-3
Original file line numberDiff line numberDiff line change
@@ -2,10 +2,11 @@
22

33
## Dependencies
44

5-
If you want to help development you need:
6-
75
* [.NET Core 2.0 SDK](https://microsoft.com/net/core/)
86
* Docker
7+
* NBXplorer
8+
* PostgreSQL
9+
* Bitcoin Core (optionally other full nodes)
910

1011
## Which IDE?
1112

@@ -18,4 +19,4 @@ You need an instance of NBXplorer, Postgres, and Bitcoin Core running and config
1819

1920
To simplify the development process we created a docker-compose file which setup everything for your dev environment, you can find all the information in [the README of the test project](https://github.com/btcpayserver/btcpayserver/blob/master/BTCPayServer.Tests/README.md).
2021

21-
Both Visual Studio Code and Visual Studio 2017 will run the debug profile Docker-Regtest, which will run a BTCPay server instance connecting to the services in your docker service so you can easily debug and step through the code.
22+
Both Visual Studio Code and Visual Studio 2017 will run the debug profile Docker-Regtest, which will run a BTCPayServer instance connecting to the services in your Docker service, so you can easily debug and step through the code.

ManualDeployment.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,6 @@ The process is basically the following:
66
2. Clone and run [NBXplorer](https://github.com/dgarage/NBxplorer)
77
3. Clone and run [BTCPay Server](https://github.com/btcpayserver/btcpayserver)
88

9-
Take a look to our video to learn more:
9+
Take a look at our video to learn more:
1010

1111
[![BTCPay - Setup](http://img.youtube.com/vi/Xo_vApXTZBU/mqdefault.jpg)](http://www.youtube.com/watch?v=Xo_vApXTZBU "BTCPay - Setup")

README.md

+23-18
Original file line numberDiff line numberDiff line change
@@ -20,37 +20,42 @@ This solution is for you if:
2020
## Documentation
2121

2222
### Getting started
23-
* [Try it on our test servers](Getting-Started.md)
2423

25-
### Deployment
24+
* [Try it on our test servers](TryItOut.md)
2625
* [Architecture](Architecture.md)
27-
* [Manual deployment](ManualDeployment.md)
26+
27+
### Deployment
28+
29+
* [Azure deployment (simplest)](AzureDeployment.md)
2830
* [Docker deployment](DockerDeployment.md)
29-
* [Azure deployment](AzureDeployment.md)
30-
* [Third party hosting](Managed.md)
31-
* [Hosting Provider: How to deploy on LunaNode](https://medium.com/@BtcpayServer/hosting-btcpayserver-on-lunanode-bf9ef5fff75b)
32-
* ~~[Hosting Provider: How to deploy on time4vps](https://medium.com/@BtcpayServer/hosting-btcpay-server-for-cheap-2b27761fdb9d)~~ (They do not officially support docker yet)
31+
* [Manual deployment (not recommended)](ManualDeployment.md)
32+
* [Third party hosting](ThirdPartyHosting.md)
33+
* [BTC-accepting Hosting Provider: How to deploy on LunaNode](https://medium.com/@BtcpayServer/hosting-btcpayserver-on-lunanode-bf9ef5fff75b)
34+
* ~~[BTC-accepting Hosting Provider: How to deploy on time4vps](https://medium.com/@BtcpayServer/hosting-btcpay-server-for-cheap-2b27761fdb9d)~~ (They do not officially support docker yet)
3335

34-
### Get engaged
35-
* [How to contribute](Local-Development.md)
36-
* [How to get support](Support.md)
37-
* [Connect with the community](Community.md)
36+
### Integrations
3837

39-
### Integration
4038
* [Drupal](Drupal.md)
4139
* [Woocommerce](Woocommerce.md)
4240
* [Custom integration](CustomIntegration.md)
4341

42+
### Tips & tricks
43+
44+
* [FAQ](FAQ.md)
45+
* [How to change the domain name of your BTCPay Server](ChangeDomain.md)
46+
* [The guide for penny pinching your Microsoft Azure bill](PennyPinching.md)
47+
48+
### Get engaged
49+
50+
* [How to contribute](LocalDevelopment.md)
51+
* [How to get support](Support.md)
52+
* [Connect with the community](Community.md)
53+
4454
### Community articles
55+
4556
* [The Ultimate Guide to BTCPay - The free and open-source Bitcoin Payment processor](https://www.reddit.com/r/Bitcoin/comments/8f1eqf/the_ultimate_guide_to_btcpay_the_free_and/)
4657
* [The Ultimate List of BTCPay Server Hosts and Merchants](https://bitcoinshirt.co/btcpay-stores/)
4758
* [Xadrez - Guide to run an open source based e-store that accepts Litecoin, Bitcoin and fiat](Xadrez.md)
4859
* [Third party hosted BTCPay servers - If you are looking for help with BTCPay Server](Managed.md)
4960
* [BTCPay Server official youtube channel](https://www.youtube.com/channel/UCpG9WL6TJuoNfFVkaDMp9ug)
5061

51-
## Administrating your server
52-
* [How to change the domain name of your BTCPay Server](ChangeDomain.md)
53-
* [The guide for penny pinching your Microsoft Azure bill](PennyPinching.md)
54-
55-
### More
56-
* [FAQ](FAQ.md)

Support.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22

33
This project is open source, and is not a company. Instead we rely on a network of contributors and users to provide support.
44

5-
Here are some member of the community that you can contact to get additional paid support,
5+
Here are some members of the community that you can contact to get additional paid support:
66

77
### Hubik Tomas
88

Managed.md ThirdPartyHosting.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
1-
# Third party hosted BTCPay servers
1+
# Third-party hosting
22

3-
You are maybe interested in BTCPay Server, but you maybe don't have the necessary experience to set it up? Or you maybe want to be able to call somebody in case you have an issue? Please have a look at the following services, all have another focus:
3+
Are you interested in BTCPayServer, but not comfortable setting it up? Or maybe you want to be able to call somebody if you have an issue? Please have a look at the following services for third-party hosting:
44

55
* [lightbo.lt](https://lightbo.lt)
66
* [ltcpay.com](https://ltcpay.com/)

Getting-Started.md TryItOut.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# Getting Started
1+
# Try it out
22

33
This section goes through the process of creating an account and store on our public BTCPay server. (For evaluation purpose)
44

Woocommerce.md WooCommerce.md

+2-3
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
# WooCommerce integration
22

3-
You can checkout the following video, or head out to [the woocommerce plugin repository](https://github.com/btcpayserver/woocommerce-plugin).
4-
5-
[![WooCommerce](https://img.youtube.com/vi/tTH3nLoyTcw/mqdefault.jpg)](https://www.youtube.com/watch?v=tTH3nLoyTcw "BTCPay - WooCommerce")
3+
You can check out the following video, or head over to [the WooCommerce plugin repository](https://github.com/btcpayserver/woocommerce-plugin).
64

5+
[![WooCommerce](https://img.youtube.com/vi/tTH3nLoyTcw/mqdefault.jpg)](https://www.youtube.com/watch?v=tTH3nLoyTcw "BTCPay - WooCommerce")

0 commit comments

Comments
 (0)