* Inject wallet logger interface * Include method in NWC logs * Fix wrong page total * Poll for new logs every second * Fix overlapping pagination * Remove unused total * Better logs for incoming payments * Use _setLogs instead of wrapper * Remove inconsistent receive log * Remove console.log from wallet logger on server * Fix missing 'wallet detached' log * Fix confirm_withdrawl code * Remove duplicate autowithdrawal log * Add context to log * Add more context * Better table styling * Move CSS for wallet logs into one file * remove unused logNav class * rename classes * Align key with second column * Fix TypeError if context empty * Check content-type header before calling res.json() * Fix duplicate 'failed to create invoice' * Parse details from LND error * Fix invalid DOM property 'colspan' * P2P zap logs with context * Remove unnecessary withdrawal error log * the code assignment was broken anyway * we already log withdrawal errors using .catch on payViaPaymentRequest * Don't show outgoing fee to receiver to avoid confusion * Fix typo in comment * Log if invoice was canceled by payer * Automatically populate context from bolt11 * Fix missing context * Fix wrap errors not logged * Only log cancel if client canceled * Remove unused imports * Log withdrawal/forward success/error in payment flow * Fix boss not passed to checkInvoice * Fix TypeError * Fix database timeouts caused by logger The logger shares the same connection pool with any currently running transaction. This means that we enter a classic deadlock when we await logger calls: the logger call is waiting for a connection but the currently running transaction is waiting for the logger call to finish before it can release a connection. * Fix cache returning undefined * Fix typo in comment * Add padding-right to key in log context * Always use 'incoming payment failed:' --------- Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
56 lines
1.5 KiB
JavaScript
56 lines
1.5 KiB
JavaScript
import { msatsToSats } from '@/lib/format'
|
|
import { getAgent } from '@/lib/proxy'
|
|
import { assertContentTypeJson } from '@/lib/url'
|
|
import fetch from 'cross-fetch'
|
|
|
|
export * from 'wallets/lnbits'
|
|
|
|
export async function testCreateInvoice ({ url, invoiceKey }) {
|
|
return await createInvoice({ msats: 1000, expiry: 1 }, { url, invoiceKey })
|
|
}
|
|
|
|
export async function createInvoice (
|
|
{ msats, description, descriptionHash, expiry },
|
|
{ url, invoiceKey }) {
|
|
const path = '/api/v1/payments'
|
|
|
|
const headers = new Headers()
|
|
headers.append('Accept', 'application/json')
|
|
headers.append('Content-Type', 'application/json')
|
|
headers.append('X-Api-Key', invoiceKey)
|
|
|
|
// lnbits doesn't support msats so we have to floor to nearest sat
|
|
const sats = msatsToSats(msats)
|
|
|
|
const body = JSON.stringify({
|
|
amount: sats,
|
|
unit: 'sat',
|
|
expiry,
|
|
memo: description,
|
|
out: false
|
|
})
|
|
|
|
let hostname = url.replace(/^https?:\/\//, '')
|
|
const agent = getAgent({ hostname })
|
|
|
|
if (process.env.NODE_ENV !== 'production' && hostname.startsWith('localhost:')) {
|
|
// to make it possible to attach LNbits for receives during local dev
|
|
hostname = 'lnbits:5000'
|
|
}
|
|
|
|
const res = await fetch(`${agent.protocol}//${hostname}${path}`, {
|
|
method: 'POST',
|
|
headers,
|
|
agent,
|
|
body
|
|
})
|
|
if (!res.ok) {
|
|
assertContentTypeJson(res)
|
|
const errBody = await res.json()
|
|
throw new Error(errBody.detail)
|
|
}
|
|
|
|
const payment = await res.json()
|
|
return payment.payment_request
|
|
}
|