* 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>
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { withTimeout } from '@/lib/time'
 | 
						|
import { getScopes, SCOPE_READ, SCOPE_RECEIVE, SCOPE_WRITE, getWallet, request } from 'wallets/blink/common'
 | 
						|
import { msatsToSats } from '@/lib/format'
 | 
						|
export * from 'wallets/blink'
 | 
						|
 | 
						|
export async function testCreateInvoice ({ apiKeyRecv, currencyRecv }) {
 | 
						|
  const scopes = await getScopes(apiKeyRecv)
 | 
						|
  if (!scopes.includes(SCOPE_READ)) {
 | 
						|
    throw new Error('missing READ scope')
 | 
						|
  }
 | 
						|
  if (scopes.includes(SCOPE_WRITE)) {
 | 
						|
    throw new Error('WRITE scope must not be present')
 | 
						|
  }
 | 
						|
  if (!scopes.includes(SCOPE_RECEIVE)) {
 | 
						|
    throw new Error('missing RECEIVE scope')
 | 
						|
  }
 | 
						|
 | 
						|
  const timeout = 15_000
 | 
						|
  currencyRecv = currencyRecv ? currencyRecv.toUpperCase() : 'BTC'
 | 
						|
  return await withTimeout(createInvoice({ msats: 1000, expiry: 1 }, { apiKeyRecv, currencyRecv }), timeout)
 | 
						|
}
 | 
						|
 | 
						|
export async function createInvoice (
 | 
						|
  { msats, description, expiry },
 | 
						|
  { apiKeyRecv, currencyRecv }) {
 | 
						|
  currencyRecv = currencyRecv ? currencyRecv.toUpperCase() : 'BTC'
 | 
						|
 | 
						|
  const wallet = await getWallet(apiKeyRecv, currencyRecv)
 | 
						|
 | 
						|
  if (currencyRecv !== 'BTC') {
 | 
						|
    throw new Error('unsupported currency ' + currencyRecv)
 | 
						|
  }
 | 
						|
  const mutation = `
 | 
						|
        mutation LnInvoiceCreate($input: LnInvoiceCreateInput!) {
 | 
						|
            lnInvoiceCreate(input: $input) {
 | 
						|
                invoice {
 | 
						|
                    paymentRequest
 | 
						|
                }
 | 
						|
                errors {
 | 
						|
                    message
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
    `
 | 
						|
 | 
						|
  const out = await request(apiKeyRecv, mutation, {
 | 
						|
    input: {
 | 
						|
      amount: msatsToSats(msats),
 | 
						|
      expiresIn: Math.floor(expiry / 60) || 1,
 | 
						|
      memo: description,
 | 
						|
      walletId: wallet.id
 | 
						|
    }
 | 
						|
  })
 | 
						|
  const res = out.data.lnInvoiceCreate
 | 
						|
  const errors = res.errors
 | 
						|
  if (errors && errors.length > 0) {
 | 
						|
    throw new Error(errors.map(e => e.code + ' ' + e.message).join(', '))
 | 
						|
  }
 | 
						|
  const invoice = res.invoice.paymentRequest
 | 
						|
  return invoice
 | 
						|
}
 |