You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardexpand all lines: docs/WooCommerce.md
+50-42
Original file line number
Diff line number
Diff line change
@@ -15,6 +15,8 @@ If you do not have a store yet, follow [this step by step article](https://web.a
15
15
This guide refers to the BTCPay for WooCommerce V2 plugin. You can find instructions for the now unmaintained legacy plugin (based on BitPay API) [here](https://github.com/btcpayserver/btcpayserver-doc/blob/cba96292ceea9483711ab53c479a98357383f857/docs/WooCommerce.md).

103
-
4. Click on the *"Select specific stores"* link for the following permissions: `View invoices`, `Create invoice`, `Modify invoices`, `Modify stores webhooks`, `View your stores`
104
-

105
-
5. Click on *[Generate API Key]*
106
-

107
-
6. Copy the generated API Key to your WordPress *BTCPay Settings* form
108
-

109
-
7. Copy the store ID to your WordPress *BTCPay Settings* form
110
-

111
-
8. On the BTCPay Settings form make sure *BTPCay Server URL*, *BTCPay Server API Key* and *Store ID* are set and click *[Save]*
112
-
9. Make sure you see the notification "*BTCPay Server: Successfully registered a new webhook on BTCPay Server*"
113
-

105
+
4. Click on the *"Select specific stores"* link for the following permissions: `View invoices`, `Create invoice`, `Modify invoices`, `Modify stores webhooks`, `View your stores`, `Create non-approved pull payments` (used for refunds)
106
+

107
+
5. Click on *[Generate API Key]*
108
+

109
+
6. Copy the generated API Key to your WordPress *BTCPay Settings* form
110
+

111
+
7. Copy the store ID to your WordPress *BTCPay Settings* form
112
+

113
+
8. On the BTCPay Settings form make sure *BTPCay Server URL*, *BTCPay Server API Key* and *Store ID* are set and click *[Save]*
114
+
9. Make sure you see the notification "*BTCPay Server: Successfully registered a new webhook on BTCPay Server*"
115
+

114
116
115
117
## 3. Testing the checkout
116
118
@@ -126,27 +128,27 @@ The final video guides you through the steps of setting a gap limit in your Elec
126
128
127
129
Can be found at *WooCommerce -> Settings -> Tab [BTCPay Settings]*
128
130
129
-
**BTCPay Server URL**
131
+
**BTCPay Server URL**
130
132
131
133
URL to your BTCPay Server instance, including protocol e.g. `https://btcpay.yourdomain.com`.
132
134
133
-
**BTCPay API Key**
135
+
**BTCPay API Key**
134
136
135
137
Your API Key. (Was auto-generated in the steps before).
136
138
137
-
**Store ID**
139
+
**Store ID**
138
140
139
141
The store ID of your BTCPay Server store. Can be found on the store settings page.
140
142
141
-
**Default Customer Message**
143
+
**Default Customer Message**
142
144
143
145
Here you can customize the customer message shown after selecting BTCPay payment gateway on checkout. This can be overwritten on the payment gateway settings for each gateway if you use the "Separate payment gateways" option.
144
146
145
-
**Invoice pass to "Settled" state after**
147
+
**Invoice pass to "Settled" state after**
146
148
147
149
Set after how many confirmations a payment is considered fully paid and settled. Defaults to what is configured on BTCPay store settings.
148
150
149
-
**BTCPay Order Statuses**
151
+
**BTCPay Order Statuses**
150
152
151
153
Depending on your business model and store settings, you may want to configure your order statuses.
152
154
You can set BTCPay to trigger certain order status in WooCommerce automatically.
@@ -168,15 +170,15 @@ Another example, if a merchant wants to send an email notifying the customer tha
168
170
169
171
It takes some time to find a perfect formula, so users should test things out before going live.
170
172
171
-
**Separate Payment Gateways**
173
+
**Separate Payment Gateways**
172
174
173
-
If this option is enabled the plugin will generate one separate payment gateway per supported payment method on BTCPay Server. E.g. if you have BTC, LightningNetwork and maybe Liquid Assets enabled on your BTCPay Server store, then you will have a separate gateway available for each. This allows many new use cases like discount per gateway or country based restrictions. More details [here](./FAQ/Integrations/#how-to-configure-additional-token-support).
175
+
If this option is enabled the plugin will generate one separate payment gateway per supported payment method on BTCPay Server. E.g. if you have BTC, LightningNetwork and maybe Liquid Assets enabled on your BTCPay Server store, then you will have a separate gateway available for each. This allows many new use cases like discount per gateway or country based restrictions. More details [here](./FAQ/Integrations/#how-to-configure-additional-token-support).
174
176
175
-
**Send customer data to BTCPayServer**
177
+
**Send customer data to BTCPayServer**
176
178
177
179
By default *no* customer data beside email is sent to BTCPay Server. If you want to send customer address data to BTCPay Server you can enable it here.
178
180
179
-
**Debug Log**
181
+
**Debug Log**
180
182
181
183
This option is helpful in case you have a problem and need more information on what is going on. The logs can be then found under WooCommerce -> Status -> Log. Make sure you disable this again after debugging as it will fill up your filesystem with logs.
182
184
@@ -187,10 +189,10 @@ Depending on wheter you have above mentioned "Separate Payment Gateways" enabled
187
189
188
190
On all payment gateways you can set the following options:
189
191
190
-
**Title**
192
+
**Title**
191
193
The shown payment gateway text on the checkout page. Defaults to "BTCPay (Bitcoin, Lightning Network, ...)".
192
194
193
-
**Customer Message**
195
+
**Customer Message**
194
196
195
197
Here you can customize message shown after selecting BTCPay payment gateway.
196
198
@@ -214,19 +216,19 @@ Additional options only available for the separate payment gateways (if that fea
214
216
215
217
By default type "payment" is selected. But if you have Liquid Assets with your own issued asset/token (e.g. used as voucher) you can select "promotion" here. Those are processed differently than normal payment tokens. Details can be found [here](./FAQ/Integrations/#how-to-configure-additional-token-support#promotional-tokens-100-discount)
216
218
217
-
# Troubleshooting
219
+
##Troubleshooting
218
220
219
-
## Error: Call to undefined function BTCPayServer\Http\curl_init()
220
-
Please make sure your PHP version supports the cURL extension (as written in the requirements above). You can install it on Debian/Ubuntu by running the command `sudo apt install php-curl`.
221
+
###Error: Call to undefined function BTCPayServer\Http\curl_init()
222
+
Please make sure your PHP version supports the cURL extension (as written in the requirements above). You can install it on Debian/Ubuntu by running the command `sudo apt install php-curl`.
221
223
222
-
## The order states do not update although the invoice has been paid
224
+
###The order states do not update although the invoice has been paid
223
225
Please check first if the webhook is created under the BTCPay Server store settings. If there is no webhook created you can visit on your WooCommerce store BTCPay Settings tab under WooCommerce settings and hit the save button. This will create the webhook.
224
226
225
-
You may also check the details of your invoice if there were any errors on sending the webhook request. Some hosting providers, firewall setups or WordPress security plugins (like Wordfence) block POST requests to your WordPress site which lead to a http status of "403 Forbidden" or "503 Service Unavailable".
227
+
You may also check the details of your invoice if there were any errors on sending the webhook request. Some hosting providers, firewall setups or WordPress security plugins (like Wordfence) block POST requests to your WordPress site which lead to a http status of "403 Forbidden" or "503 Service Unavailable".
226
228
227
229
You can check and verify yourself if there is something blocking requests to your site in one of these two ways:
228
230
229
-
**Check using a command line (Linux or MacOS):**
231
+
**Check using a command line (Linux or MacOS):**
230
232
(replace EXAMPLE.COM with your WordPress site URL)
231
233
232
234
```
@@ -239,14 +241,14 @@ On the response, if you see that line "HTTP/1.1 500" or "HTTP/2 500" and the mes
@@ -265,9 +267,9 @@ On the other side, if you see that line "HTTP/1.1 403 Forbidden" or "HTTP/2 403"
265
267
< Content-Length: 26
266
268
```
267
269
268
-
**Check using an online service (if you do not have a command line available:**
270
+
**Check using an online service (if you do not have a command line available:**
269
271
270
-
- Go to [https://reqbin.com/post-online](https://reqbin.com/post-online)
272
+
- Go to [https://reqbin.com/post-online](https://reqbin.com/post-online)
271
273
- Enter your domain: `https://EXAMPLE.COM/?wc-api=btcpaygf_default`
272
274
(replace EXAMPLE.COM with your WordPress site URL)
273
275
- Make sure "POST" is selected
@@ -278,23 +280,29 @@ On the other side, if you see that line "HTTP/1.1 403 Forbidden" or "HTTP/2 403"
278
280
279
281
If you see "Status 403 (Forbidden)" then POST requests to your site are blocked for some reason. You should ask your hosting provider or make sure no firewall or plugin is blocking the requests.
280
282
281
-
## I get an error during checkout but not sure what the problem is.
283
+
###I get an error during checkout but not sure what the problem is.
282
284
283
285
In your BTCPay Settings in your admin dashboard: *WooCommerce -> Settings: Tab [BTCPay Settings]* you can enable debug mode by setting the checkbox on that option.
284
286
285
-
You can now find more detailed Logs when you click the [View Logs] button or you go to *WooCommerce -> Status: Tab [Logs]* and select the most recent btcpay logs.
287
+
You can now find more detailed Logs when you click the [View Logs] button or you go to *WooCommerce -> Status: Tab [Logs]* and select the most recent btcpay logs.
286
288
287
289
:::warning Warning
288
290
Please make sure that you disable the debugging mode again after you finished investigating, otherwise your site performance may be impacted and also write lots of logging data in your filesystem for no reason.
289
-
:::
291
+
:::
290
292
291
293
Additionally you can also look into your webservers error logs if you find any error that is related to BTCPay plugin.
292
294
293
-
## I have troubles with using the plugin or some other related questions
295
+
###I have troubles with using the plugin or some other related questions
294
296
295
297
Feel free to join our support channel over at [https://chat.btcpayserver.org/](https://chat.btcpayserver.org/) if you need help or have any further questions.
296
298
299
+
### Create a new API key
300
+
301
+
If you have been using the WooCommerce V2 plugin prior to version 2.0.0, your API key won't have the required permissions to issue refunds via pull-payments. If you want to use that feature, you can create a new API key (editing an API key is not currently supported). You can use the above described [2.1 Connect using API key wizard](#21-connect-using-the-api-key-wizard--recommended-) or the [manual API key generation](#22-connect-by-manually-creating-the-api-key-and-permissions). The configured webhook will continue to work, and no change is needed.
302
+
303
+
### I messed around with the webhook, how to fix
297
304
305
+
Suppose you accidentally changed the WooCommerce webhook, and it is not working anymore. In that case, you can quickly force a re-creation of it when you delete the API key on BTCPay Server and then go to the BTCPay Server Settings (on your WordPress site) and hit save again. You should see a message that the webhook was successfully created.
0 commit comments