btcpayserver/BTCPayServer/Views/Stores/SetupLightningNode.cshtml

162 lines
7.5 KiB
Text
Raw Normal View History

2021-04-19 16:21:50 +02:00
@model LightningNodeViewModel
@{
Layout = "_LayoutWalletSetup.cshtml";
ViewData.SetActivePageAndTitle(StoreNavPages.Index, "Configure your Lightning node", Context.GetStoreData().StoreName);
}
@section Navbar {
<a asp-controller="Stores" asp-action="UpdateStore" asp-route-storeId="@Model.StoreId">
<vc:icon symbol="back" />
</a>
}
<header class="text-center">
<h1>@ViewData["Title"]</h1>
<div class="d-flex mt-4 mb-5">
<vc:icon symbol="warning" />
<p class="text-secondary text-left mb-0">
Please understand that the Lightning Network is still under active development and considered experimental.
Before you proceed, take time to familiarize yourself with the risks.
<a href="https://docs.btcpayserver.org/LightningNetwork/" target="_blank">More information</a>
</p>
</div>
</header>
<style>
header .icon-warning {
flex: 0 0 24px;
height: 24px;
align-self: center;
margin-right: 2rem;
color: var(--btcpay-color-warning);
}
#InternalSetup, #CustomSetup, #LightningNodeType-Internal, #LightningNodeType-Custom { display: none; }
#LightningNodeType-Internal:checked + * + * + * + #InternalSetup,
#LightningNodeType-Custom:checked + * + *+ #CustomSetup { display: block; }
#LightningNodeType-Internal:checked + label, #LightningNodeType-Custom:checked + label {
color: var(--btcpay-color-white);
background: var(--btcpay-color-primary);
}
label[for="LightningNodeType-Internal"], label[for="LightningNodeType-Custom"] {
display: inline-block;
padding: .75rem 2rem;
color: var(--btcpay-color-primary);
font-weight: var(--btcpay-font-weight-semibold);
border-radius: 1.5rem;
cursor: pointer;
}
#LightningNodeType-Internal[disabled]:checked + label[for="LightningNodeType-Internal"] {
background: var(--btcpay-color-secondary);
color: var(--btcpay-color-white);
opacity: .5;
}
#LightningNodeType-Internal[disabled] + label[for="LightningNodeType-Internal"] {
color: var(--btcpay-color-secondary);
opacity: .5;
}
#CustomSetup ul {
list-style: none;
padding-left: 0;
}
#CustomSetup ul li code {
color: var(--btcpay-code-color);
}
#CustomSetup ul li > code {
display: block;
color: var(--btcpay-code-color);
background: var(--btcpay-code-bg);
margin: .5rem 0;
padding: .75rem 1rem;
border-radius: .25rem;
}
</style>
<form method="post" class="mt-n2 text-center">
<input asp-for="LightningNodeType" value="@LightningNodeType.Internal" type="radio" id="LightningNodeType-@LightningNodeType.Internal" disabled="@(!Model.CanUseInternalNode)">
<label asp-for="LightningNodeType" for="@($"LightningNodeType-{LightningNodeType.Internal}")">Internal node</label>
<input asp-for="LightningNodeType" value="@LightningNodeType.Custom" type="radio" id="LightningNodeType-@LightningNodeType.Custom">
<label asp-for="LightningNodeType" for="@($"LightningNodeType-{LightningNodeType.Custom}")">Custom node</label>
<div id="InternalSetup" class="text-left">
@if (Model.CanUseInternalNode)
{
<p class="my-4">That's it, no need to configure anything else.</p>
<button id="saveInternal" name="command" type="submit" value="save" class="btn btn-primary mr-2">Use internal node</button>
}
else
{
<p class="my-4">Only administrators can use the internal Lightning node.</p>
}
</div>
<div id="CustomSetup" class="text-left">
<label asp-for="ConnectionString" class="mt-4">The connection string configuration for your custom Lightning node:</label>
<div class="d-sm-flex">
<input asp-for="ConnectionString" class="form-control mb-2 mr-2" placeholder="type=…;server=…;" value="@(Model.LightningNodeType == LightningNodeType.Internal ? "" : Model.ConnectionString)"/>
<button id="test" name="command" type="submit" value="test" class="btn btn-secondary text-nowrap mb-2">Test connection</button>
</div>
<span asp-validation-for="ConnectionString" class="text-danger"></span>
<p class="mt-4 mb-2">BTCPay Server currently supports:</p>
<ul>
<li class="mb-3">
<strong>c-lightning</strong> via TCP or unix domain socket connection:
<ul>
<li>
<code><b>type=</b>clightning;<b>server=</b>unix://root/.lightning/lightning-rpc</code>
</li>
<li>
<code><b>type=</b>clightning;<b>server=</b>tcp://1.1.1.1:27743/</code>
</li>
</ul>
</li>
<li class="mb-3">
<strong>Lightning Charge</strong> via HTTPS:
<ul>
<li>
<code><b>type=</b>charge;<b>server=</b>https://charge:8080/;<b>api-token=</b>myapitoken...</code>
</li>
</ul>
</li>
<li class="mb-3">
<strong>Eclair</strong> via HTTPS:
<ul>
<li>
<code><b>type=</b>eclair;<b>server=</b>https://eclair:8080/;<b>password=</b>eclairpassword...</code>
</li>
</ul>
</li>
<li class="mb-3">
<strong>LND</strong> via the REST proxy:
<ul>
<li>
<code><b>type=</b>lnd-rest;<b>server=</b>https://mylnd:8080/;<b>macaroon=</b>abef263adfe...</code>
</li>
<li>
<code><b>type=</b>lnd-rest;<b>server=</b>https://mylnd:8080/;<b>macaroon=</b>abef263adfe...;<b>certthumbprint=</b>abef263adfe...</code>
</li>
</ul>
<a class="d-inline-block text-decoration-none" data-toggle="collapse" href="#lnd-notes" role="button" aria-expanded="false" aria-controls="lnd-notes">
More information on the LND settings
</a>
<div id="lnd-notes" class="collapse pt-2">
<p>
For the macaroon options you need to provide the <code>admin.macaroon</code>.<br/>
The path to the LND data directory may vary, the following examples assume <code>/root/.lnd</code>.
</p>
<p class="mb-2">The <code>macaroon</code> parameter expects the HEX value, it can be obtained using this command:</p>
<pre class="mb-4">xxd -plain /root/.lnd/data/chain/bitcoin/mainnet/admin.macaroon | tr -d '\n'</pre>
<p class="mb-2">
You can omit <code>certthumbprint</code> if the certificate is trusted by your machine.<br/>
The <code>certthumbprint</code> can be obtained using this command:
</p>
<pre class="mb-4">openssl x509 -noout -fingerprint -sha256 -in /root/.lnd/tls.cert | sed -e 's/.*=//;s/://g'</pre>
<p class="mb-0">If your LND REST server is using HTTP or HTTPS with an untrusted certificate, you can set <code>allowinsecure=true</code> as a fallback.</p>
</div>
</li>
</ul>
<button id="saveCustom" name="command" type="submit" value="save" class="btn btn-primary mr-2">Use custom node</button>
</div>
</form>
@section Scripts {
<partial name="_ValidationScriptsPartial" />
}