# Setting up BTCPay Server for Conference / Event / Local Community
We will be going through the setup we used at Bitcoin Atlantis (opens new window), Bitcoin Hong Kong (opens new window), Bitcoin Nashville (opens new window) and other conferences for a great user experience for attendees and merchants.
For Point of Sale (PoS) devices we use the Bitcoinize (opens new window) devices with receipt printer (but you can use any other Android-based PoS device).
The Lightning Network part will be done by Blink.sv (opens new window) with the Blink plugin (but you can swap it for any other LN service like Alby, Breez, use our internal LN node or connect to your own LN node).
To allow an even smoother UX for attendees without an internet connection or no prior Bitcoin knowledge we show how to set up and issue Bolt Cards and allow users to top-up.
To get an overview of the whole setup and steps you can watch our workshop from BTCPrague 2024.
Table of contents
- Initial setup
- Setup merchant stores and initialize Bitcoinize devices
- Setup merchant stores
- 1. Create store
- 2. Setup Lightning Network wallet
- 3. Configure spread and enable sounds
- 4. Setup Point of Sale (PoS)
- 5. Put PoS link and labels on Bitcoinize device
- 6. Give merchants access to the payment history (optional, but recommended)
- 7. Increase Rate Limits if You Haven't Logged in Merchants on Devices (Optional)
- Setup a Bolt Cards provider
# Initial setup
- Setup BTCPay Server v2.0.5 or later on a VPS (with public IP)
- Setup a subdomain or use one provided by VPS hosting (e.g. Lunanode)
- Register the admin account and create a first test store
- Do FastSync (optional)
Once the server is up, install these plugins:
- Blink plugin
- Bolt Cards plugin
Then restart BTCPay Server (via UI or docker restart generated_btcpayserver_1
via SSH)
# Setup merchant stores and initialize Bitcoinize devices
# Preparation of Bitcoinize devices
- Make sure Bitcoinize devices battery level is 90%+ (if less, then charge)
- Extension cords / high-powered USB hubs are critical when setting up 10+ devices
- Insert the paper roll in the device's printer
# Setup merchant stores
Log into your BTCPay Server instance with your admin account.
Repeat the following steps for each merchant:
# 1. Create store
- Top left dropdown -> "Create store" button
- Name: e.g. Nakamoto's Pineapple Pizza
- Default Currency: USD, HKD, ... depending on location
- Preferred Price Source: For USD, EUR Kraken is recommended, HKD Coingecko, for more exotic currencies you can try Coingecko or check if there is a local exchange listed in the dropdown
- Click "Create store" button
# 2. Setup Lightning Network wallet
Setup the Lightning wallet to be connected to the merchants' Blink account, follow the instructions on Blink docs (opens new window). (Alternatively, in case your merchants want to get paid in local currency you can set up your conference Blink account and distribute funds later on fiat ramps)
# 3. Configure spread and enable sounds
- Click "Settings" -> "Rates"
- Add Exchange Rate Spread: enter
1
, so we have extra room (Blink charges 0.2% for hedging in StableSats USD - Click "Save" button
- Click "Settings" -> "Checkout Appearance"
- On dropdown "Select a preset", select "In-store"
- Click "Save" button
# 4. Setup Point of Sale (PoS)
- Left sidebar under "Plugins", click on "Point of Sale"
- "App Name": enter the same merchant name as for the store
- Click "Create" button
- Now on PoS settings, make sure "App Name" and "Display Title" are filled out
- "Choose Point of Sale Style": select "Keypad"
- "Currency", select the same currency as your store
- Click on "Save" button
- On the top right click on the "View" button and make sure the keypad is shown
# 5. Put PoS link and labels on Bitcoinize device
- Go back to PoS settings in your browser and click on the "QR-code icon"
- On your Bitcoinize (or other) device, open the "Camera" app
- Scroll to the right until you find "more" category -> select "QR-Code"
- Now scan the QR-Code shown in your browser (on the PoS settings page)
- After scanning open the URL in the Chrome browser
- Check that you see the keypad and the correct merchant name
- Tap on the 3 dots "..." on the top right and select "Add to home"
- Place the icon on the main home screen for easy access
- Label the device and box with stickers bearing the merchant name
Testing the PoS device payments and give permissions:
- Start the PoS page from the home screen
- Ensure that the sound on the device is turned up so that there is audio feedback on payment, especially if Bolt Cards are used
- Enter 0.01 USD (or other currency equivalent) and tap on "Charge" button
- Only first time the browser will ask for NFC permission, tap on the button to give it the requested permission
- Pay the invoice either with a Bolt Card or Lightning wallet
- Ensure you hear the sound after the payment
- Tap on "View receipt" button, test printing the receipt by selecting the POSPrinter from the dropdown, tap on the "Print" button
# 6. Give merchants access to the payment history (optional, but recommended)
Optionally you can also create a login for each store/merchant on the PoS device so they can access the payment history. This is helpful to double-check what was the last payment or if a payment was already made. You can do so by adding a "Merchant" role with the following permissions:
- btcpay.store.canmodifyinvoices
- btcpay.store.canviewstoresettings
- btcpay.store.canviewpaymentrequestes
- btcpay.store.canarchivepullpayments
- btcpay.store.cancreatenonapprovedpullpayments
After that create a user for each store and assign them to the right store.
# 7. Increase Rate Limits if You Haven't Logged in Merchants on Devices (Optional)
By default, the create invoice
endpoint is throttled by IP to 4 requests per minute for public requests. If you are sharing an IP across multiple POS devices, you may encounter issues where more than 4 invoices cannot be created simultaneously during stress testing.
In a November 2024 PR (opens new window), we ensured that this throttling does not apply to logged-in users. Therefore, if you completed Step 6, this issue won’t affect you. However, if you prefer not to log in users on each device, you can increase the rate limit as follows:
- Go to Manage Plugins on your BTCPay Server instance and install the Dynamic Rate Limit plugin by Kukks.
- Navigate to
/plugins/dynamicrateslimiter
(Server Settings -> Dynamic Reports -> Rate Limits). - Click on Add Rate Limit and enter the following value:
zone=publicinvoices rate=9999r/m burst=500 nodelay
This change allows anyone to create up to 9999 invoices per minute from any IP. For this reason, completing Step 6 (logging in users on devices) is the recommended approach.
# Setup a Bolt Cards provider
We will create a separate store that is serving as a Bolt Cards provider. To find it easier in the list of stores you can append the store name with a "z", e.g. "z - Bolt Cards Provider".
For this special store we will connect a Blink account with the important differences compared to merchant Blink accounts:
- the API key has to have also write permission, otherwise Bolt Cards won't be able to pull the funds
- Make sure you connect the Bitcoin wallet (and not StableSats USD)
# 1. Create a store
- Create a store with the name "z - Bolt Cards Provider" (same steps as shown for merchant stores above)
# 2. Setup Lightning Network wallet
Setup the Lightning wallet to be connected to your Blink account as per instructions on Blink docs (opens new window) but make sure:
- the API key has "Read", "Receive" and "Write" permissions, otherwise Bolt Cards won't be able to pull the funds
- make sure you connect to the Bitcoin wallet (and not StableSats USD)
# 3. Setup automated payouts
To allow no-interaction top-ups of Bolt Cards we need to make sure payouts are processing automatically.
- Go "Settings" -> "Payout Processors"
- Below "Automated Lightning Sender", click on "Configure"
- Enable "**Process approved payouts instantly"
- Click on "Save" button
# 4. Setup Bolt Cards Factory
# Setup a Bolt Card factory
- On the left sidebar go to "Boltcard Factories"
- "App Name": Enter a name like "Your conference" (it will be displayed when the card is read)
- Click on the "Create" button, and you will see the following settings. For example, if you want to preload the cards with 210 Sats, enter the following:
- "Name": Name of the conference/event that is displayed when a Bolt Card is read
- "Amount": 210
- "Currency": SATS (The currency must to be SATS, do not set any other currency)
- "Automatically approve claims": checked (true)
- "Payment Methods": "BTC (Off-Chain)" checked (true)
- Click on "Save" button
# Program Bolt Cards
Still, on that Boltcards Factory settings page, you now click on "View" button on the top right, the page that opens will need to be opened on a mobile device with NFC writing support (e.g. a Bitcoinize device).
- Ensure that you have the Bolt Card NFC Card Creator (opens new window) installed on the mobile device
- If there is a Bolt Card NFC Card Creator app already installed - make sure it's the latest version, optionally uninstall and install the newest version from the app store
- When you click on the "Setup" button on the Boltcard Factory it should open the Bolt Card NFC Card Creator app
- Make sure you hold the Bolt Card *until ALL green checkmarks are done
- You can now batch initialize cards. Just click on the "Write again" button
# 5. Checking the balance of cards and topping them up
In the same store that serves as the Bolt Card provider you will have a "Boltcard Balance" menu item on the left sidebar. The URL will look like this https://btcpay.yourdomain.tld/boltcards/balance (opens new window)
When you open that link on a mobile device with NFC support (such as Bitcoinize), you can use it to allow users to check their balance and also for topping their cards up with Sats, to do that, tap on the "QR-Code icon" after reading the balance of the card.
# 6. Resetting Bolt Cards after the conference/event
Like the balance page, you can find the link on the left sidebar. The URL will look like this https://btcpay.yourdomain.tld/boltcards/balance?view=Reset (opens new window)
You should consider publishing this link during or even before the event and allow attendees to sweep and reset their cards after the event, so they can reuse the Bolt Cards and reprogram them. This is only possible after the reset is done successfully.
To reset Bolt Cards, like for setting them up, you need the Bolt Card NFC Card Creator app.
See this tweet by Uncle Rockstar Dev (opens new window) how the instructions could look like.
Congratulations, you have now set up a BTCPay Server for a conference or event with a smooth user experience for attendees and merchants. Enjoy the event!