* 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>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { assertContentTypeJson } from '@/lib/url'
 | |
| 
 | |
| export * from 'wallets/lnbits'
 | |
| 
 | |
| export async function testSendPayment ({ url, adminKey, invoiceKey }, { logger }) {
 | |
|   logger.info('trying to fetch wallet')
 | |
| 
 | |
|   url = url.replace(/\/+$/, '')
 | |
|   await getWallet({ url, adminKey, invoiceKey })
 | |
| 
 | |
|   logger.ok('wallet found')
 | |
| }
 | |
| 
 | |
| export async function sendPayment (bolt11, { url, adminKey }) {
 | |
|   url = url.replace(/\/+$/, '')
 | |
| 
 | |
|   const response = await postPayment(bolt11, { url, adminKey })
 | |
| 
 | |
|   const checkResponse = await getPayment(response.payment_hash, { url, adminKey })
 | |
|   if (!checkResponse.preimage) {
 | |
|     throw new Error('No preimage')
 | |
|   }
 | |
| 
 | |
|   return checkResponse.preimage
 | |
| }
 | |
| 
 | |
| async function getWallet ({ url, adminKey, invoiceKey }) {
 | |
|   const path = '/api/v1/wallet'
 | |
| 
 | |
|   const headers = new Headers()
 | |
|   headers.append('Accept', 'application/json')
 | |
|   headers.append('Content-Type', 'application/json')
 | |
|   headers.append('X-Api-Key', adminKey || invoiceKey)
 | |
| 
 | |
|   const res = await fetch(url + path, { method: 'GET', headers })
 | |
|   if (!res.ok) {
 | |
|     assertContentTypeJson(res)
 | |
|     const errBody = await res.json()
 | |
|     throw new Error(errBody.detail)
 | |
|   }
 | |
| 
 | |
|   const wallet = await res.json()
 | |
|   return wallet
 | |
| }
 | |
| 
 | |
| async function postPayment (bolt11, { url, adminKey }) {
 | |
|   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', adminKey)
 | |
| 
 | |
|   const body = JSON.stringify({ bolt11, out: true })
 | |
| 
 | |
|   const res = await fetch(url + path, { method: 'POST', headers, body })
 | |
|   if (!res.ok) {
 | |
|     assertContentTypeJson(res)
 | |
|     const errBody = await res.json()
 | |
|     throw new Error(errBody.detail)
 | |
|   }
 | |
| 
 | |
|   const payment = await res.json()
 | |
|   return payment
 | |
| }
 | |
| 
 | |
| async function getPayment (paymentHash, { url, adminKey }) {
 | |
|   const path = `/api/v1/payments/${paymentHash}`
 | |
| 
 | |
|   const headers = new Headers()
 | |
|   headers.append('Accept', 'application/json')
 | |
|   headers.append('Content-Type', 'application/json')
 | |
|   headers.append('X-Api-Key', adminKey)
 | |
| 
 | |
|   const res = await fetch(url + path, { method: 'GET', headers })
 | |
|   if (!res.ok) {
 | |
|     assertContentTypeJson(res)
 | |
|     const errBody = await res.json()
 | |
|     throw new Error(errBody.detail)
 | |
|   }
 | |
| 
 | |
|   const payment = await res.json()
 | |
|   return payment
 | |
| }
 |