bitcoin-s/docs/next/config/configuration.html
Docusaurus bot db5866cd5a Deploy website
Deploy website version based on 5475a994cf
2022-03-20 00:35:39 +00:00

548 lines
No EOL
50 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html><html lang="en"><head><meta charSet="utf-8"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><title>Application Configuration · bitcoin-s</title><meta name="viewport" content="width=device-width, initial-scale=1.0"/><meta name="generator" content="Docusaurus"/><meta name="description" content="Bitcoin-S uses [HOCON](https://github.com/lightbend/config/blob/master/HOCON.md)"/><meta name="docsearch:version" content="next"/><meta name="docsearch:language" content="en"/><meta property="og:title" content="Application Configuration · bitcoin-s"/><meta property="og:type" content="website"/><meta property="og:url" content="https://bitcoin-s.org/"/><meta property="og:description" content="Bitcoin-S uses [HOCON](https://github.com/lightbend/config/blob/master/HOCON.md)"/><meta property="og:image" content="https://bitcoin-s.org/img/undraw_online.svg"/><meta name="twitter:card" content="summary"/><meta name="twitter:image" content="https://bitcoin-s.org/img/undraw_tweetstorm.svg"/><link rel="shortcut icon" href="/img/favicon.ico"/><link rel="stylesheet" href="https://cdn.jsdelivr.net/docsearch.js/1/docsearch.min.css"/><link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/default.min.css"/><script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-61958686-2', 'auto');
ga('send', 'pageview');
</script><link rel="stylesheet" href="/css/code-block-buttons.css"/><script type="text/javascript" src="https://buttons.github.io/buttons.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.0/clipboard.min.js"></script><script type="text/javascript" src="https://fonts.googleapis.com/css?family=Montserrat:500"></script><script type="text/javascript" src="https://www.googletagmanager.com/gtag/js?id=UA-61958686-2"></script><script type="text/javascript" src="/js/code-block-buttons.js"></script><script src="/js/scrollSpy.js"></script><link rel="stylesheet" href="/css/main.css"/><script src="/js/codetabs.js"></script></head><body class="sideNavVisible separateOnPageNav"><div class="fixedHeaderContainer"><div class="headerWrapper wrapper"><header><a href="/"><img class="logo" src="/img/favicon.ico" alt="bitcoin-s"/><h2 class="headerTitleWithLogo">bitcoin-s</h2></a><a href="/versions"><h3>next</h3></a><div class="navigationWrapper navigationSlider"><nav class="slidingNav"><ul class="nav-site nav-site-internal"><li class="siteNavGroupActive"><a href="/docs/next/core/core-intro" target="_self">Docs</a></li><li class=""><a href="/download" target="_self">Download</a></li><li class=""><a href="/api/org/bitcoins" target="_self">API</a></li><li class=""><a href="/help" target="_self">Help</a></li><li class="navSearchWrapper reactNavSearchWrapper"><input type="text" id="search_input_react" placeholder="Search" title="Search"/></li></ul></nav></div></header></div></div><div class="navPusher"><div class="docMainWrapper wrapper"><div class="docsNavContainer" id="docsNav"><nav class="toc"><div class="toggleNav"><section class="navWrapper wrapper"><div class="navBreadcrumb wrapper"><div class="navToggle" id="navToggler"><div class="hamburger-menu"><div class="line1"></div><div class="line2"></div><div class="line3"></div></div></div><h2><i></i><span>Configuration</span></h2><div class="tocToggler" id="tocToggler"><i class="icon-toc"></i></div></div><div class="navGroups"><div class="navGroup"><h3 class="navGroupCategoryTitle">Getting Started</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/getting-started">Intro and Getting Started</a></li><li class="navListItem"><a class="navItem" href="/docs/next/bips">Supported BIPs</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Getting Setup</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/getting-setup">Getting Bitcoin-S installed on your machine</a></li><li class="navListItem"><a class="navItem" href="/docs/next/ui-setup">Installing the DLC Wallet UI</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Applications</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/applications/cli">CLI</a></li><li class="navListItem"><a class="navItem" href="/docs/next/applications/server">Application Server</a></li><li class="navListItem"><a class="navItem" href="/docs/next/applications/gui">GUI</a></li><li class="navListItem"><a class="navItem" href="/docs/next/applications/server-systemd">Systemd installation</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Chain</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/chain/chain">Blockchain Verification</a></li><li class="navListItem"><a class="navItem" href="/docs/next/chain/filter-sync">Syncing Blockfilters</a></li><li class="navListItem"><a class="navItem" href="/docs/next/chain/chain-query-api">Chain Query API</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Configuration</h3><ul class=""><li class="navListItem navListItemActive"><a class="navItem" href="/docs/next/config/configuration">Application Configuration</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Core Module</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/core/core-intro">Core Module</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/addresses">Generating Addresses</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/hd-keys">HD Key Generation</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/adding-spks">Adding New Script Types</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/spending-info">Signing Transactions</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/psbts">Partially Signed Bitcoin Transactions</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/dlc">Discreet Log Contract Data Structures</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/txbuilder">TxBuilder Example</a></li><li class="navListItem"><a class="navItem" href="/docs/next/core/lightning-network">Lightning Network Data Types</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Crypto Module</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/crypto/crypto-intro">Crypto Module</a></li><li class="navListItem"><a class="navItem" href="/docs/next/crypto/sign">Sign API</a></li><li class="navListItem"><a class="navItem" href="/docs/next/crypto/adaptor-signatures">Adaptor Signatures</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Fee Provider</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/fee-provider/fee-provider">Fee Provider</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Key Manager</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/key-manager/server-key-manager">Server Key Manager</a></li><li class="navListItem"><a class="navItem" href="/docs/next/key-manager/key-manager">Key Manager</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Node</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/node/node">Light Client</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Wallet</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet">Wallet</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-callbacks">Wallet Callbacks</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-get-address">Wallet Get Address APIs</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/address-tagging">Address and UTXO tagging</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/dlc">Executing A DLC with Bitcoin-S</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-rescan">wallet/wallet-rescan</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-sync">Wallet Sync</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-rpc">Wallet RPC Examples</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/backups">Wallet Backups</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-election-example">Wallet Election Example</a></li><li class="navListItem"><a class="navItem" href="/docs/next/wallet/wallet-price-example">Wallet Price Example</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Tor</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/tor/tor">Tor Setup</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">RPC Clients</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/rpc/rpc-clients-intro">Introduction</a></li><li class="navListItem"><a class="navItem" href="/docs/next/rpc/rpc-eclair">Eclair</a></li><li class="navListItem"><a class="navItem" href="/docs/next/rpc/rpc-bitcoind">bitcoind/Bitcoin Core</a></li><li class="navListItem"><a class="navItem" href="/docs/next/rpc/lnd-rpc">LND</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Secp256k1</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/secp256k1/secp256k1">Secp256k1</a></li><li class="navListItem"><a class="navItem" href="/docs/next/secp256k1/jni-modify">Adding to Secp256k1 JNI</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Testkit</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/testkit/testkit">Testkit</a></li><li class="navListItem"><a class="navItem" href="/docs/next/testkit/testkit-core">Testkit Core</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">DLC Oracle</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/oracle/build-oracle-server">Building the Oracle Server</a></li><li class="navListItem"><a class="navItem" href="/docs/next/oracle/oracle-server">Oracle Server</a></li><li class="navListItem"><a class="navItem" href="/docs/next/oracle/oracle-election-example">Election Example</a></li><li class="navListItem"><a class="navItem" href="/docs/next/oracle/oracle-price-example">Price Example</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Oracle Explorer Client</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/oracle-explorer-client/oracle-explorer-client">Oracle Explorer Client</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Contributing</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/contributing">Contributing</a></li><li class="navListItem"><a class="navItem" href="/docs/next/contributing-website">Contributing to the website</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle">Security</h3><ul class=""><li class="navListItem"><a class="navItem" href="/docs/next/security">Security</a></li></ul></div></div></section></div><script>
var coll = document.getElementsByClassName('collapsible');
var checkActiveCategory = true;
for (var i = 0; i < coll.length; i++) {
var links = coll[i].nextElementSibling.getElementsByTagName('*');
if (checkActiveCategory){
for (var j = 0; j < links.length; j++) {
if (links[j].classList.contains('navListItemActive')){
coll[i].nextElementSibling.classList.toggle('hide');
coll[i].childNodes[1].classList.toggle('rotate');
checkActiveCategory = false;
break;
}
}
}
coll[i].addEventListener('click', function() {
var arrow = this.childNodes[1];
arrow.classList.toggle('rotate');
var content = this.nextElementSibling;
content.classList.toggle('hide');
});
}
document.addEventListener('DOMContentLoaded', function() {
createToggler('#navToggler', '#docsNav', 'docsSliderActive');
createToggler('#tocToggler', 'body', 'tocActive');
var headings = document.querySelector('.toc-headings');
headings && headings.addEventListener('click', function(event) {
var el = event.target;
while(el !== headings){
if (el.tagName === 'A') {
document.body.classList.remove('tocActive');
break;
} else{
el = el.parentNode;
}
}
}, false);
function createToggler(togglerSelector, targetSelector, className) {
var toggler = document.querySelector(togglerSelector);
var target = document.querySelector(targetSelector);
if (!toggler) {
return;
}
toggler.onclick = function(event) {
event.preventDefault();
target.classList.toggle(className);
};
}
});
</script></nav></div><div class="container mainContainer docsContainer"><div class="wrapper"><div class="post"><header class="postHeader"><a class="edit-page-link button" href="https://github.com/bitcoin-s/bitcoin-s/blob/master/docs/config/configuration.md" target="_blank" rel="noreferrer noopener">Edit</a><h1 id="__docusaurus" class="postHeaderTitle">Application Configuration</h1></header><article><div><span><p>Bitcoin-S uses <a href="https://github.com/lightbend/config/blob/master/HOCON.md">HOCON</a>
to configure various parts of the application the library offers. HOCON is a superset of JSON, that is, all valid JSON
is valid HOCON.</p>
<p>All configuration for Bitcoin-S is under the <code>bitcoin-s</code> key.</p>
<p>If you have a file <code>application.conf</code> anywhere on your classpath when using bitcoin-s, the values there take precedence
over the ones found in our
<code>reference.conf</code>. We also look for the file <code>bitcoin-s.conf</code> in the current Bitcoin-S data directory.</p>
<p>The resolved configuration gets parsed by
<a href="/api/org/bitcoins/db/AppConfig"><code>AppConfig</code></a>.
<code>AppConfig</code> is an abstract class that's implemented by corresponding case classes in the <code>wallet</code>, <code>chain</code> and <code>node</code>
projects. Here's some examples of how to construct a wallet configuration:</p>
<pre><code class="hljs css language-scala"><span class="hljs-keyword">import</span> org.bitcoins.wallet.config.<span class="hljs-type">WalletAppConfig</span>
<span class="hljs-keyword">import</span> com.typesafe.config.<span class="hljs-type">ConfigFactory</span>
<span class="hljs-keyword">import</span> java.nio.file.<span class="hljs-type">Paths</span>
<span class="hljs-keyword">import</span> scala.util.<span class="hljs-type">Properties</span>
<span class="hljs-keyword">import</span> scala.concurrent.<span class="hljs-type">ExecutionContext</span>.<span class="hljs-type">Implicits</span>.global
<span class="hljs-comment">// reads $HOME/.bitcoin-s/</span>
<span class="hljs-keyword">val</span> defaultConfig = <span class="hljs-type">WalletAppConfig</span>.fromDefaultDatadir()
<span class="hljs-comment">// reads a custom data directory</span>
<span class="hljs-keyword">val</span> customDirectory = <span class="hljs-type">Paths</span>.get(<span class="hljs-type">Properties</span>.userHome, <span class="hljs-string">"custom-bitcoin-s-directory"</span>)
<span class="hljs-keyword">val</span> configFromCustomDatadir = <span class="hljs-type">WalletAppConfig</span>(customDirectory, <span class="hljs-type">Vector</span>.empty)
<span class="hljs-comment">// reads a custom data directory and overrides the network to be testnet3</span>
<span class="hljs-keyword">val</span> customOverride = <span class="hljs-type">ConfigFactory</span>.parseString(<span class="hljs-string">"bitcoin-s.network = testnet3"</span>)
<span class="hljs-keyword">val</span> configFromCustomDirAndOverride = <span class="hljs-type">WalletAppConfig</span>(customDirectory, <span class="hljs-type">Vector</span>(customOverride))
</code></pre>
<p>You can pass as many <code>com.typesafe.config.Config</code>s as you'd like. If any keys appear multiple times the last one
encountered takes precedence.</p>
<h2><a class="anchor" aria-hidden="true" id="command-line-options"></a><a href="#command-line-options" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Command Line Options</h2>
<p>There are a few command line options available that take precedence over configuration file.</p>
<ul>
<li><p><code>--datadir &lt;directory&gt;</code></p>
<p><code>datadir</code> sets the data directory instead of using the default <code>$HOME/.bitcoin-s</code></p></li>
<li><p><code>--rpcbind &lt;ip&gt;</code></p>
<p><code>rpcbind</code> sets the interface the rpc server binds to instead of using the default <code>127.0.0.1</code></p></li>
<li><p><code>--rpcport &lt;port&gt;</code></p>
<p><code>rpcport</code> sets the port the rpc server binds to instead of using the default <code>9999</code></p></li>
<li><p><code>--force-recalc-chainwork</code></p>
<p><code>force-recalc-chainwork</code> will force a recalculation of the entire chain's chain work, this can be useful if there is
an incompatible migration or if it got out of sync.</p></li>
<li><p><code>-Dlogback.configurationFile=/path/to/config.xml</code></p>
<p>You can set a custom logback configuration. If you need help creating a custom logback file you can
read <a href="http://logback.qos.ch/manual/configuration.html">the logback configuration documentation</a>.</p></li>
</ul>
<h2><a class="anchor" aria-hidden="true" id="internal-configuration"></a><a href="#internal-configuration" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Internal configuration</h2>
<p>Database connections are also configured by using HOCON. This is done
in <a href="https://github.com/bitcoin-s/bitcoin-s/blob/master/db-commons/src/main/resources/reference.conf"><code>reference.conf</code></a>
inside the <code>db-commons</code> module. The options exposed here are <strong>not</strong> intended to be used by users of Bitcoin-S, and are
internal only.</p>
<h2><a class="anchor" aria-hidden="true" id="database-migrations"></a><a href="#database-migrations" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Database Migrations</h2>
<p>All of our modules that require databases now have database migrations. The tool we use for these migrations is
called <a href="https://flywaydb.org/">flyway</a>. To find your projects migraitons, you need to look inside of the
<code>[project-name]/src/main/resources/[database-name]/migration/</code>. For example, the chain projects migrations live under
the path <code>chain/src/main/resources/chaindb/migration/V1__chain_db_baseline.sql</code>.</p>
<p>Migrations can be executed by calling
the <a href="https://github.com/bitcoin-s/bitcoin-s/blob/e387d075b0ff2e0a0fec15788fcb48e4ddc4d9d5/db-commons/src/main/scala/org/bitcoins/db/DbManagement.scala#L92"><code>DbManagement.migrate()</code></a>
method. Migrations are applied by default on server startup, via
the <a href="https://github.com/bitcoin-s/bitcoin-s/blob/master/db-commons/src/main/scala/org/bitcoins/db/AppConfig.scala#L49"><code>AppConfig.start()</code></a>
method.</p>
<p>These migrations are setup so that project's databases and migrations are independent of each other. Therefore if you
want to use the <code>bitcoin-s-chain</code> project, but not the <code>bitcoin-s-wallet</code> project, wallet migrations are not applied. It
should be noted if you are using a module as a library, you are responsible for configuring the database via
<a href="https://scala-slick.org/doc/3.3.1/database.html#using-typesafe-config">slick's configuration</a> and calling
<a href="https://github.com/bitcoin-s/bitcoin-s/blob/master/db-commons/src/main/scala/org/bitcoins/db/AppConfig.scala#L49"><code>AppConfig.start()</code></a>
to ensure the entire module is initialized correctly.</p>
<h2><a class="anchor" aria-hidden="true" id="example-configuration-file"></a><a href="#example-configuration-file" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Example Configuration File</h2>
<pre><code class="hljs css language-$xslt">bitcoin-s {
<span class="hljs-comment"># the network your bitcoin-s node is running on</span>
<span class="hljs-attr">network</span> = <span class="hljs-string">"testnet3"</span> <span class="hljs-comment"># regtest, testnet3, mainnet, signet</span>
<span class="hljs-comment"># specify what backend you are using with bitcoin-s</span>
<span class="hljs-comment"># by default we do neutrino, but you can also connect</span>
<span class="hljs-comment"># bitcoind with the configuration settings in bitcoin-s.bitcoind-rpc</span>
node.<span class="hljs-attr">mode</span> = neutrino <span class="hljs-comment"># neutrino, bitcoind</span>
<span class="hljs-comment"># configurations for connecting to bitcoind</span>
bitcoind-rpc {
<span class="hljs-comment"># bitcoind rpc username</span>
<span class="hljs-attr">rpcuser</span> = user
<span class="hljs-comment"># bitcoind rpc password</span>
<span class="hljs-comment"># If your password contains the characters '$','{', '}', '[', ']', ':', '=', ',', '+', '#', '`', '^', '?', '!', '@', '*', '&amp;', whitespace</span>
<span class="hljs-comment"># or the string "//", enclose it in double quotes</span>
<span class="hljs-comment"># rpcpassword = "password=" if the original password is password=, rpcpassword = "passwo//rd" if the original password is passwo//rd etc.</span>
<span class="hljs-comment"># If it contains '\' or '"', escape it with '\'</span>
<span class="hljs-comment"># rpcpassword = "pass\\word" if the original password is pass\word, rpcpassword = "pass\"word" if the original password is pass"word</span>
<span class="hljs-attr">rpcpassword</span> = password
<span class="hljs-comment"># Binary location of bitcoind</span>
<span class="hljs-attr">binary</span> = ${HOME}/.bitcoin-s/binaries/bitcoind/bitcoin-<span class="hljs-number">0.20</span>.<span class="hljs-number">1</span>/bin/bitcoind
<span class="hljs-comment"># bitcoind datadir</span>
<span class="hljs-attr">datadir</span> = ${HOME}/.bitcoin
<span class="hljs-comment"># bitcoind network host</span>
<span class="hljs-attr">connect</span> = localhost
<span class="hljs-comment"># bitcoind p2p port</span>
<span class="hljs-attr">port</span> = <span class="hljs-number">8333</span>
<span class="hljs-comment"># bitcoind rpc host</span>
<span class="hljs-attr">rpcconnect</span> = localhost
<span class="hljs-comment"># bitcoind rpc port</span>
<span class="hljs-attr">rpcport</span> = <span class="hljs-number">8332</span>
<span class="hljs-comment"># bitcoind zmq raw tx</span>
<span class="hljs-attr">zmqpubrawtx</span> = <span class="hljs-string">"tcp://127.0.0.1:28332"</span>
<span class="hljs-comment"># bitcoind zmq raw block</span>
<span class="hljs-attr">zmqpubrawblock</span> = <span class="hljs-string">"tcp://127.0.0.1:28333"</span>
<span class="hljs-comment"># bitcoind zmq hash tx</span>
<span class="hljs-attr">zmqpubhashtx</span> = <span class="hljs-string">"tcp://127.0.0.1:28330"</span>
<span class="hljs-comment"># bitcoind zmq raw block</span>
<span class="hljs-attr">zmqpubhashblock</span> = <span class="hljs-string">"tcp://127.0.0.1:28331"</span>
<span class="hljs-comment">#If you have a bitcoind instance that is running remotely on another machine, you should set it to true</span>
<span class="hljs-attr">isRemote</span> = <span class="hljs-literal">false</span>
}
<span class="hljs-comment"># settings if you are using a neutrino node in bitcoin-s</span>
node {
<span class="hljs-comment"># a list of peer addresses in form "hostname:portnumber"</span>
<span class="hljs-comment"># Port number is optional, the default value is 8333 for mainnet,</span>
<span class="hljs-comment"># 18333 for testnet and 18444 for regtest.</span>
<span class="hljs-comment"># by default we provide a testnet peer to connect to</span>
<span class="hljs-attr">peers</span> = [<span class="hljs-string">"neutrino.testnet3.suredbits.com:18333"</span>]
<span class="hljs-attr">hikari-logging</span> = <span class="hljs-literal">true</span>
<span class="hljs-attr">hikari-logging-interval</span> = <span class="hljs-number">10</span> minute
<span class="hljs-comment"># whether to have p2p peers relay us unconfirmed txs</span>
<span class="hljs-attr">relay</span> = <span class="hljs-literal">false</span>
}
proxy {
<span class="hljs-comment"># You can configure SOCKS5 proxy to use Tor for outgoing connections</span>
<span class="hljs-attr">enabled</span> = <span class="hljs-literal">false</span>
<span class="hljs-attr">socks5</span> = <span class="hljs-string">"127.0.0.1:9050"</span>
}
<span class="hljs-comment"># tor settings</span>
tor {
<span class="hljs-comment"># You can enable Tor for incoming connections</span>
<span class="hljs-attr">enabled</span> = <span class="hljs-literal">false</span>
<span class="hljs-attr">control</span> = <span class="hljs-string">"127.0.0.1:9051"</span>
<span class="hljs-comment"># Tor daemon can be provided by the node operator.</span>
<span class="hljs-comment"># If this parameter set to true, bitcoin-s will connect the provided Tor daemon.</span>
<span class="hljs-comment"># Otherwise bitcoin-s will start its own pre-packaged daemon.</span>
<span class="hljs-attr">provided</span> = <span class="hljs-literal">false</span>
<span class="hljs-comment"># This parameter allows to use random port numbers for pre-packaged Tor daemon,</span>
<span class="hljs-comment"># which is useful if another Tor daemon instance already bound SOCKS5 and control ports.</span>
<span class="hljs-comment"># In this case bitcoin-s.tor.control and bitcoin-s.proxy.socks5</span>
<span class="hljs-comment"># addresses will be automatically changed to "localhost:&lt;random port&gt;"</span>
<span class="hljs-attr">use-random-ports</span> = <span class="hljs-literal">true</span>
<span class="hljs-comment"># The password used to arrive at the HashedControlPassword for the control port.</span>
<span class="hljs-comment"># If provided, the HASHEDPASSWORD authentication method will be used instead of</span>
<span class="hljs-comment"># the SAFECOOKIE one.</span>
<span class="hljs-comment"># password = securePassword</span>
<span class="hljs-comment"># The path to the private key of the onion service being created</span>
<span class="hljs-comment"># privateKeyPath = /path/to/priv/key</span>
}
<span class="hljs-comment"># settings for the chain module</span>
chain {
<span class="hljs-attr">force-recalc-chainwork</span> = <span class="hljs-literal">false</span>
neutrino {
filter-header-batch-size.<span class="hljs-attr">default</span> = <span class="hljs-number">2000</span>
filter-header-batch-size.<span class="hljs-attr">regtest</span> = <span class="hljs-number">10</span>
<span class="hljs-comment"># You can set a network specific filter-header-batch-size</span>
<span class="hljs-comment"># by adding a trailing `.networkId` (main, test, regtest)</span>
<span class="hljs-comment"># It is recommended to keep the main and test batch size high</span>
<span class="hljs-comment"># to keep the sync time fast, however, for regtest it should be small</span>
<span class="hljs-comment"># so it does not exceed the chain size.</span>
<span class="hljs-attr">filter-batch-size</span> = <span class="hljs-number">1000</span>
}
<span class="hljs-attr">hikari-logging</span> = <span class="hljs-literal">true</span>
<span class="hljs-attr">hikari-logging-interval</span> = <span class="hljs-number">10</span> minute
}
<span class="hljs-comment"># settings for wallet module</span>
wallet {
<span class="hljs-comment"># You can have multiple wallets by setting a different</span>
<span class="hljs-comment"># wallet name for each of them. They will each have</span>
<span class="hljs-comment"># their own unique seed and database or schema,</span>
<span class="hljs-comment"># depending on the database driver.</span>
<span class="hljs-comment"># The wallet name can contain letters, numbers, and underscores '_'.</span>
<span class="hljs-comment"># walletName = MyWallet0</span>
<span class="hljs-attr">defaultAccountType</span> = segwit <span class="hljs-comment"># legacy, segwit, nested-segwit</span>
<span class="hljs-attr">bloomFalsePositiveRate</span> = <span class="hljs-number">0.0001</span> <span class="hljs-comment"># percentage</span>
<span class="hljs-comment"># the number of consecutive addresses that we do not</span>
<span class="hljs-comment"># discover funds in before we mark as rescan as exhausted</span>
<span class="hljs-comment"># this is needed because we can never truely tell how many addresses</span>
<span class="hljs-comment"># the wallet has used when executing a rescan from a seed</span>
<span class="hljs-attr">addressGapLimit</span> = <span class="hljs-number">100</span>
<span class="hljs-comment"># the number of addresses that get generated everytime</span>
<span class="hljs-comment"># we need to rescan. If a match occurs within the addressGapLimit</span>
<span class="hljs-comment"># we generate another discoveryBatchSize addresses and then rescan again</span>
<span class="hljs-attr">discoveryBatchSize</span> = <span class="hljs-number">100</span>
<span class="hljs-attr">requiredConfirmations</span> = <span class="hljs-number">6</span>
<span class="hljs-comment"># Expected average fee rate over the long term</span>
<span class="hljs-comment"># in satoshis per virtual byte</span>
<span class="hljs-attr">longTermFeeRate</span> = <span class="hljs-number">10</span>
<span class="hljs-comment"># How big the address queue size is before we throw an exception</span>
<span class="hljs-comment"># because of an overflow</span>
<span class="hljs-attr">addressQueueSize</span> = <span class="hljs-number">10</span>
<span class="hljs-comment"># How long we attempt to generate an address for</span>
<span class="hljs-comment"># before we timeout</span>
<span class="hljs-attr">addressQueueTimeout</span> = <span class="hljs-number">5</span> seconds
<span class="hljs-comment"># Allow external payout and change addresses in DLCs</span>
<span class="hljs-comment"># By default all DLC addresses are generated by the wallet itself</span>
<span class="hljs-attr">allowExternalDLCAddresses</span> = <span class="hljs-literal">false</span>
<span class="hljs-comment"># How often the wallet will rebroadcast unconfirmed transactions</span>
<span class="hljs-attr">rebroadcastFrequency</span> = <span class="hljs-number">4</span> hours
<span class="hljs-attr">hikari-logging</span> = <span class="hljs-literal">true</span>
<span class="hljs-attr">hikari-logging-interval</span> = <span class="hljs-number">10</span> minute
}
keymanager {
<span class="hljs-comment"># You can optionally set a BIP 39 password</span>
<span class="hljs-comment"># bip39password = "changeMe"</span>
<span class="hljs-comment"># Password that your seed is encrypted with</span>
<span class="hljs-comment"># aesPassword = changeMe</span>
<span class="hljs-comment"># At least 16 bytes of entropy encoded in hex</span>
<span class="hljs-comment"># This will be used as the seed for any</span>
<span class="hljs-comment"># project that is dependent on the keymanager</span>
<span class="hljs-comment"># entropy = ""</span>
}
<span class="hljs-comment"># Bitcoin-S provides manny different fee providers</span>
<span class="hljs-comment"># You can configure your server to use any of them</span>
<span class="hljs-comment"># Below is some examples of different options</span>
fee-provider {
<span class="hljs-comment"># name = mempoolspace # Uses mempool.space's api</span>
<span class="hljs-comment"># The target is optional for mempool.space</span>
<span class="hljs-comment"># It refers to the expected number of blocks until confirmation</span>
<span class="hljs-comment"># target = 6</span>
<span class="hljs-comment"># name = bitcoinerlive # Uses bitcoiner.live's api</span>
<span class="hljs-comment"># The target is optional for Bitcoiner Live</span>
<span class="hljs-comment"># It refers to the expected number of blocks until confirmation</span>
<span class="hljs-comment"># target = 6</span>
<span class="hljs-comment"># name = bitgo # Uses BitGo's api</span>
<span class="hljs-comment"># The target is optional for BitGo</span>
<span class="hljs-comment"># It refers to the expected number of blocks until confirmation</span>
<span class="hljs-comment"># target = 6</span>
<span class="hljs-comment"># name = constant # A constant fee rate in sats/vbyte</span>
<span class="hljs-comment"># target = 1 # Will always use 1 sat/vbyte</span>
}
dlcnode {
<span class="hljs-comment"># The address we are listening on for incoming connections for DLCs</span>
<span class="hljs-comment"># Binding to 0.0.0.0 makes us listen to all incoming connections</span>
<span class="hljs-comment"># Consider using 127.0.0.1 listen address if Tor is enabled.</span>
<span class="hljs-comment"># listen = "0.0.0.0:2862"</span>
<span class="hljs-comment"># The address our peers use to connect to our node. </span>
<span class="hljs-comment"># By default it's the same as the listen address, </span>
<span class="hljs-comment"># or if Tor is enabled, the hidden service's onion address.</span>
<span class="hljs-comment"># You can specify a port number like this "192.168.0.1:12345", </span>
<span class="hljs-comment"># The default port number is the same as in the listen adrress </span>
<span class="hljs-comment"># external-ip = "192.168.0.1" </span>
}
server {
<span class="hljs-comment"># The port we bind our rpc server on</span>
<span class="hljs-attr">rpcport</span> = <span class="hljs-number">9999</span>
<span class="hljs-comment"># The ip address we bind our server too</span>
<span class="hljs-attr">rpcbind</span> = <span class="hljs-string">"127.0.0.1"</span>
<span class="hljs-comment"># The port we bind our websocket server on</span>
<span class="hljs-attr">wsport</span> = <span class="hljs-number">19999</span>
<span class="hljs-comment"># The ip address we bind the websocket server too</span>
<span class="hljs-attr">wsbind</span> = <span class="hljs-string">"127.0.0.1"</span>
<span class="hljs-comment"># The basic auth password. It must me must be non empty.</span>
<span class="hljs-attr">password</span> = topsecret
}
oracle {
<span class="hljs-comment"># The port we bind our rpc server on</span>
<span class="hljs-attr">rpcport</span> = <span class="hljs-number">9998</span>
<span class="hljs-comment"># The ip address we bind our server too</span>
<span class="hljs-attr">rpcbind</span> = <span class="hljs-string">"127.0.0.1"</span>
<span class="hljs-comment"># The basic auth password. It must me must be non empty.</span>
<span class="hljs-attr">password</span> = supersecret
<span class="hljs-attr">hikari-logging</span> = <span class="hljs-literal">true</span>
<span class="hljs-attr">hikari-logging-interval</span> = <span class="hljs-number">10</span> minute
db {
<span class="hljs-attr">path</span> = ${bitcoin-s.datadir}/oracle/
}
}
<span class="hljs-attr">dbDefault</span> = {
<span class="hljs-attr">dataSourceClass</span> = slick.jdbc.DatabaseUrlDataSource
<span class="hljs-attr">profile</span> = <span class="hljs-string">"slick.jdbc.SQLiteProfile$"</span>
db {
<span class="hljs-comment"># for information on parameters available here see</span>
<span class="hljs-comment"># https://scala-slick.org/doc/3.3.1/api/index.html#slick.jdbc.JdbcBackend$DatabaseFactoryDef@forConfig(String,Config,Driver,ClassLoader):Database</span>
<span class="hljs-attr">path</span> = ${bitcoin-s.datadir}/${bitcoin-s.network}/
<span class="hljs-attr">driver</span> = org.sqlite.JDBC
<span class="hljs-attr">user</span> = <span class="hljs-string">""</span>
<span class="hljs-attr">password</span> = <span class="hljs-string">""</span>
<span class="hljs-attr">host</span> = localhost
<span class="hljs-attr">port</span> = <span class="hljs-number">5432</span>
<span class="hljs-comment"># this needs to be set to 1 for SQLITE as it does not support concurrent database operations</span>
<span class="hljs-comment"># see: https://github.com/bitcoin-s/bitcoin-s/pull/1840</span>
<span class="hljs-attr">numThreads</span> = <span class="hljs-number">1</span>
<span class="hljs-attr">queueSize=5000</span>
<span class="hljs-attr">connectionPool</span> = <span class="hljs-string">"HikariCP"</span>
<span class="hljs-attr">registerMbeans</span> = <span class="hljs-literal">true</span>
}
<span class="hljs-attr">hikari-logging</span> = <span class="hljs-literal">false</span>
<span class="hljs-attr">hikari-logging-interval</span> = <span class="hljs-number">10</span> minute
}
testkit {
pg {
<span class="hljs-comment">#enabled postgres backend database for all test cases</span>
<span class="hljs-attr">enabled</span> = <span class="hljs-literal">false</span>
}
}
}
akka {
<span class="hljs-attr">loglevel</span> = <span class="hljs-string">"OFF"</span>
<span class="hljs-attr">stdout-loglevel</span> = <span class="hljs-string">"OFF"</span>
http {
client {
<span class="hljs-comment"># The time after which an idle connection will be automatically closed.</span>
<span class="hljs-comment"># Set to `infinite` to completely disable idle connection timeouts.</span>
<span class="hljs-comment"># some requests potentially take a long time, like generate and prune</span>
<span class="hljs-attr">idle-timeout</span> = <span class="hljs-number">5</span> minutes
}
server {
<span class="hljs-comment"># The amount of time until a request times out on the server</span>
<span class="hljs-comment"># If you have a large payload this may need to be bumped</span>
<span class="hljs-comment"># https://doc.akka.io/docs/akka-http/current/common/timeouts.html#request-timeout</span>
<span class="hljs-attr">request-timeout</span> = <span class="hljs-number">10</span>s
}
}
actor {
debug {
<span class="hljs-comment"># enable DEBUG logging of all AutoReceiveMessages (Kill, PoisonPill etc.)</span>
<span class="hljs-attr">autoreceive=</span> off
<span class="hljs-comment"># enable function of LoggingReceive, which is to log any received message at</span>
<span class="hljs-comment"># DEBUG level</span>
<span class="hljs-attr">receive</span> = on
<span class="hljs-comment"># enable DEBUG logging of unhandled messages</span>
<span class="hljs-attr">unhandled</span> = off
<span class="hljs-comment"># enable DEBUG logging of actor lifecycle changes</span>
<span class="hljs-attr">lifecycle</span> = off
<span class="hljs-attr">event-stream=off</span>
}
}
}
</code></pre>
<h2><a class="anchor" aria-hidden="true" id="database-configuration"></a><a href="#database-configuration" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Database configuration</h2>
<p>By default, bitcoin-s uses Sqlite to store its data. It creates three Sqlite databases
in <code>~/.bitcoin-s/${network}</code>: <code>chain.sqlite</code> for <code>chain</code> project,
<code>node.sqlite</code> for <code>node</code> project and <code>wallet.sqlite</code> the wallet. This is the default configuration, it doesn't require
additional changes in the config file.</p>
<p><code>bitcoin-s</code> also supports PostgreSQL as a database backend. In order to use a PostgreSQL database for all project you
need to add following into your config file:</p>
<pre><code class="hljs css language-$xslt">bitcoin-s {
common {
<span class="hljs-attr">profile</span> = <span class="hljs-string">"slick.jdbc.PostgresProfile$"</span>
db {
<span class="hljs-attr">driver</span> = org.postgresql.Driver
<span class="hljs-comment"># these 3 options will result into a jdbc url of</span>
<span class="hljs-comment"># "jdbc:postgresql://localhost:5432/database"</span>
<span class="hljs-attr">name</span> = database
<span class="hljs-attr">host</span> = localhost
<span class="hljs-attr">port</span> = <span class="hljs-number">5432</span>
<span class="hljs-attr">user</span> = <span class="hljs-string">"user"</span>
<span class="hljs-attr">password</span> = <span class="hljs-string">"topsecret"</span>
<span class="hljs-attr">numThreads</span> = <span class="hljs-number">5</span>
<span class="hljs-comment"># http://scala-slick.org/doc/3.3.3/database.html</span>
<span class="hljs-attr">connectionPool</span> = <span class="hljs-string">"HikariCP"</span>
<span class="hljs-attr">registerMbeans</span> = <span class="hljs-literal">true</span>
}
}
chain.<span class="hljs-attr">profile</span> = ${bitcoin-s.common.profile}
chain.<span class="hljs-attr">db</span> = ${bitcoin-s.common.db}
chain.db.<span class="hljs-attr">poolName</span> = <span class="hljs-string">"chain-connection-pool"</span>
node.<span class="hljs-attr">profile</span> = ${bitcoin-s.common.profile}
node.<span class="hljs-attr">db</span> = ${bitcoin-s.common.db}
node.db.<span class="hljs-attr">poolName</span> = <span class="hljs-string">"node-connection-pool"</span>
wallet.<span class="hljs-attr">profile</span> = ${bitcoin-s.common.profile}
wallet.<span class="hljs-attr">db</span> = ${bitcoin-s.common.db}
wallet.db.<span class="hljs-attr">poolName</span> = <span class="hljs-string">"wallet-connection-pool"</span>
oracle.<span class="hljs-attr">profile</span> = ${bitcoin-s.common.profile}
oracle.<span class="hljs-attr">db</span> = ${bitcoin-s.common.db}
oracle.db.<span class="hljs-attr">poolName</span> = <span class="hljs-string">"oracle-connection-pool"</span>
}
</code></pre>
<p>The database driver will create a separate SQL namespace for each sub-project: <code>chain</code>, <code>node</code> and <code>wallet</code>.</p>
<p>Also you can use mix databases and drivers in one configuration. For example, This configuration file enables Sqlite
for <code>node</code> project (it's default, so its configuration is omitted), and <code>walletdb</code> and <code>chaindb</code> PostgreSQL databases
for <code>wallet</code> and <code>chain</code> projects:</p>
<pre><code class="hljs css language-$xslt">bitcoin-s {
chain {
<span class="hljs-built_in"> profile </span>= <span class="hljs-string">"slick.jdbc.PostgresProfile$"</span>
db {
driver = org.postgresql.Driver
name = chaindb
host = localhost
<span class="hljs-built_in"> port </span>= 5432
<span class="hljs-built_in"> user </span>= <span class="hljs-string">"user"</span>
password = <span class="hljs-string">"topsecret"</span>
}
}
wallet {
<span class="hljs-built_in"> profile </span>= <span class="hljs-string">"slick.jdbc.PostgresProfile$"</span>
db {
driver = org.postgresql.Driver
name = walletdb
host = localhost
<span class="hljs-built_in"> port </span>= 5432
<span class="hljs-built_in"> user </span>= <span class="hljs-string">"user"</span>
password = <span class="hljs-string">"topsecret"</span>
}
}
}
</code></pre>
</span></div></article></div><div class="docs-prevnext"><a class="docs-prev button" href="/docs/next/chain/chain-query-api"><span class="arrow-prev"></span><span>Chain Query API</span></a><a class="docs-next button" href="/docs/next/core/core-intro"><span>Core Module</span><span class="arrow-next"></span></a></div></div></div><nav class="onPageNav"><ul class="toc-headings"><li><a href="#command-line-options">Command Line Options</a></li><li><a href="#internal-configuration">Internal configuration</a></li><li><a href="#database-migrations">Database Migrations</a></li><li><a href="#example-configuration-file">Example Configuration File</a></li><li><a href="#database-configuration">Database configuration</a></li></ul></nav></div><footer class="nav-footer" id="footer"><section class="sitemap"><a href="/" class="nav-home"><img src="/img/favicon.ico" alt="bitcoin-s" width="66" height="58"/></a><div><h5>Docs</h5><a href="/docs/en/getting-started">Getting Started</a><a href="/docs/en/core/core-intro">Guides</a><a href="/api/org/bitcoins">API Reference</a></div><div><h5>Community</h5><a href="/en/users.html">User Showcase</a><a href="https://join.slack.com/t/suredbits/shared_invite/zt-eavycu0x-WQL7XOakzQo8tAy7jHHZUw" target="_blank" rel="noreferrer noopener">Slack</a><a href="https://gitter.im/bitcoin-s-core/">Gitter chat</a></div><div><h5>More</h5><a href="https://github.com/bitcoin-s/bitcoin-s">GitHub</a><a class="github-button" href="https://github.com/bitcoin-s/bitcoin-s" data-icon="octicon-star" data-count-href="/bitcoin-s/bitcoin-s-core/stargazers" data-show-count="true" data-count-aria-label="# stargazers on GitHub" aria-label="Star this project on GitHub">Star</a></div></section><section class="copyright">Copyright © 2022 Suredbits &amp; the bitcoin-s developers</section></footer></div><script type="text/javascript" src="https://cdn.jsdelivr.net/docsearch.js/1/docsearch.min.js"></script><script>
document.addEventListener('keyup', function(e) {
if (e.target !== document.body) {
return;
}
// keyCode for '/' (slash)
if (e.keyCode === 191) {
const search = document.getElementById('search_input_react');
search && search.focus();
}
});
</script><script>
var search = docsearch({
apiKey: '0a510688bf8448e19aeb380377d328d3',
indexName: 'bitcoin-s',
inputSelector: '#search_input_react'
});
</script></body></html>