Split arguments into [value,] config, context

This commit is contained in:
ekzyis 2024-07-06 03:03:40 +02:00
parent 0ebe097a70
commit 6463e6eec8
4 changed files with 19 additions and 19 deletions

View File

@ -40,7 +40,7 @@ export function useWallet (name) {
const hash = bolt11Tags(bolt11).payment_hash const hash = bolt11Tags(bolt11).payment_hash
logger.info('sending payment:', `payment_hash=${hash}`) logger.info('sending payment:', `payment_hash=${hash}`)
try { try {
const { preimage } = await wallet.sendPayment({ bolt11, ...config, logger }) const { preimage } = await wallet.sendPayment(bolt11, config, { logger })
logger.ok('payment successful:', `payment_hash=${hash}`, `preimage=${preimage}`) logger.ok('payment successful:', `payment_hash=${hash}`, `preimage=${preimage}`)
} catch (err) { } catch (err) {
const message = err.message || err.toString?.() const message = err.message || err.toString?.()
@ -70,7 +70,7 @@ export function useWallet (name) {
// validate should log custom INFO and OK message // validate should log custom INFO and OK message
// validate is optional since validation might happen during save on server // validate is optional since validation might happen during save on server
// TODO: add timeout // TODO: add timeout
await wallet.validate?.({ me, logger, ...newConfig }) await wallet.validate?.(newConfig, { me, logger })
await saveConfig(newConfig) await saveConfig(newConfig)
logger.ok(_isConfigured ? 'wallet updated' : 'wallet attached') logger.ok(_isConfigured ? 'wallet updated' : 'wallet attached')
} catch (err) { } catch (err) {

View File

@ -21,18 +21,18 @@ export const card = {
badges: ['send only', 'non-custodialish'] badges: ['send only', 'non-custodialish']
} }
export async function validate ({ logger, url, adminKey }) { export async function validate ({ url, adminKey }, { logger }) {
logger.info('trying to fetch wallet') logger.info('trying to fetch wallet')
await getWallet(url, adminKey) await getWallet({ url, adminKey })
logger.ok('wallet found') logger.ok('wallet found')
} }
export const schema = lnbitsSchema export const schema = lnbitsSchema
export async function sendPayment ({ bolt11, url, adminKey }) { export async function sendPayment (bolt11, { url, adminKey }) {
const response = await postPayment(url, adminKey, bolt11) const response = await postPayment(bolt11, { url, adminKey })
const checkResponse = await getPayment(url, adminKey, response.payment_hash) const checkResponse = await getPayment(response.payment_hash, { url, adminKey })
if (!checkResponse.preimage) { if (!checkResponse.preimage) {
throw new Error('No preimage') throw new Error('No preimage')
} }
@ -41,8 +41,8 @@ export async function sendPayment ({ bolt11, url, adminKey }) {
return { preimage } return { preimage }
} }
async function getWallet (baseUrl, adminKey) { async function getWallet ({ url, adminKey }) {
const url = baseUrl.replace(/\/+$/, '') url = url.replace(/\/+$/, '')
const path = '/api/v1/wallet' const path = '/api/v1/wallet'
const headers = new Headers() const headers = new Headers()
@ -60,8 +60,8 @@ async function getWallet (baseUrl, adminKey) {
return wallet return wallet
} }
async function postPayment (baseUrl, adminKey, bolt11) { async function postPayment (bolt11, { url, adminKey }) {
const url = baseUrl.replace(/\/+$/, '') url = url.replace(/\/+$/, '')
const path = '/api/v1/payments' const path = '/api/v1/payments'
const headers = new Headers() const headers = new Headers()
@ -81,8 +81,8 @@ async function postPayment (baseUrl, adminKey, bolt11) {
return payment return payment
} }
async function getPayment (baseUrl, adminKey, paymentHash) { async function getPayment (paymentHash, { url, adminKey }) {
const url = baseUrl.replace(/\/+$/, '') url = url.replace(/\/+$/, '')
const path = `/api/v1/payments/${paymentHash}` const path = `/api/v1/payments/${paymentHash}`
const headers = new Headers() const headers = new Headers()

View File

@ -33,7 +33,7 @@ export const card = {
const XXX_DEFAULT_PASSWORD = 'password' const XXX_DEFAULT_PASSWORD = 'password'
export async function validate ({ me, logger, pairingPhrase, password }) { export async function validate ({ pairingPhrase, password }, { me, logger }) {
const lnc = await getLNC({ me }) const lnc = await getLNC({ me })
try { try {
lnc.credentials.pairingPhrase = pairingPhrase lnc.credentials.pairingPhrase = pairingPhrase
@ -61,7 +61,7 @@ export const schema = lncSchema
const mutex = new Mutex() const mutex = new Mutex()
async function unlock ({ lnc, password, status, showModal, logger }) { async function unlock ({ password }, { lnc, status, showModal, logger }) {
if (status === Status.Enabled) return password if (status === Status.Enabled) return password
return await new Promise((resolve, reject) => { return await new Promise((resolve, reject) => {
@ -103,7 +103,7 @@ async function unlock ({ lnc, password, status, showModal, logger }) {
} }
// FIXME: pass me, status, showModal in useWallet hook // FIXME: pass me, status, showModal in useWallet hook
export async function sendPayment ({ bolt11, pairingPhrase, password: configuredPassword, me, status, showModal, logger }) { export async function sendPayment (bolt11, { pairingPhrase, password: configuredPassword }, { me, status, showModal, logger }) {
const hash = bolt11Tags(bolt11).payment_hash const hash = bolt11Tags(bolt11).payment_hash
return await mutex.runExclusive(async () => { return await mutex.runExclusive(async () => {
@ -111,7 +111,7 @@ export async function sendPayment ({ bolt11, pairingPhrase, password: configured
try { try {
lnc = await getLNC({ me }) lnc = await getLNC({ me })
// TODO: pass status, showModal to unlock // TODO: pass status, showModal to unlock
const password = await unlock({ lnc, password: configuredPassword, status, showModal, logger }) const password = await unlock({ password: configuredPassword }, { lnc, status, showModal, logger })
// credentials need to be decrypted before connecting after a disconnect // credentials need to be decrypted before connecting after a disconnect
lnc.credentials.password = password || XXX_DEFAULT_PASSWORD lnc.credentials.password = password || XXX_DEFAULT_PASSWORD
await lnc.connect() await lnc.connect()

View File

@ -20,7 +20,7 @@ export const card = {
export const schema = nwcSchema export const schema = nwcSchema
export async function validate ({ logger, nwcUrl }) { export async function validate ({ nwcUrl }, { logger }) {
const { relayUrl, walletPubkey } = parseNwcUrl(nwcUrl) const { relayUrl, walletPubkey } = parseNwcUrl(nwcUrl)
logger.info(`requesting info event from ${relayUrl}`) logger.info(`requesting info event from ${relayUrl}`)
@ -73,7 +73,7 @@ export async function validate ({ logger, nwcUrl }) {
} }
} }
export async function sendPayment ({ bolt11, nwcUrl, logger }) { export async function sendPayment (bolt11, { nwcUrl }, { logger }) {
const { relayUrl, walletPubkey, secret } = parseNwcUrl(nwcUrl) const { relayUrl, walletPubkey, secret } = parseNwcUrl(nwcUrl)
const relay = await Relay.connect(relayUrl).catch(() => { const relay = await Relay.connect(relayUrl).catch(() => {