2024-10-23 00:53:56 +00:00
|
|
|
import walletDefs from 'wallets/client'
|
|
|
|
|
|
|
|
export const Status = {
|
|
|
|
Enabled: 'Enabled',
|
2024-10-23 17:42:34 +00:00
|
|
|
Disabled: 'Disabled'
|
2024-10-23 00:53:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export function getWalletByName (name) {
|
|
|
|
return walletDefs.find(def => def.name === name)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getWalletByType (type) {
|
|
|
|
return walletDefs.find(def => def.walletType === type)
|
|
|
|
}
|
|
|
|
|
2024-10-23 22:17:35 +00:00
|
|
|
export function getStorageKey (name, userId) {
|
2024-10-23 00:53:56 +00:00
|
|
|
let storageKey = `wallet:${name}`
|
|
|
|
|
|
|
|
// WebLN has no credentials we need to scope to users
|
|
|
|
// so we can use the same storage key for all users
|
2024-10-23 22:17:35 +00:00
|
|
|
if (userId && name !== 'webln') {
|
|
|
|
storageKey = `${storageKey}:${userId}`
|
2024-10-23 00:53:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return storageKey
|
|
|
|
}
|
|
|
|
|
|
|
|
export function walletPrioritySort (w1, w2) {
|
2024-10-23 17:42:34 +00:00
|
|
|
// enabled/configured wallets always come before disabled/unconfigured wallets
|
|
|
|
if ((w1.config?.enabled && !w2.config?.enabled) || (isConfigured(w1) && !isConfigured(w2))) {
|
|
|
|
return -1
|
|
|
|
} else if ((w2.config?.enabled && !w1.config?.enabled) || (isConfigured(w2) && !isConfigured(w1))) {
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
const delta = w1.config?.priority - w2.config?.priority
|
2024-10-23 00:53:56 +00:00
|
|
|
// delta is NaN if either priority is undefined
|
|
|
|
if (!Number.isNaN(delta) && delta !== 0) return delta
|
|
|
|
|
|
|
|
// if one wallet has a priority but the other one doesn't, the one with the priority comes first
|
2024-10-23 17:42:34 +00:00
|
|
|
if (w1.config?.priority !== undefined && w2.config?.priority === undefined) return -1
|
|
|
|
if (w1.config?.priority === undefined && w2.config?.priority !== undefined) return 1
|
2024-10-23 00:53:56 +00:00
|
|
|
|
|
|
|
// both wallets have no priority set, falling back to other methods
|
|
|
|
|
|
|
|
// if both wallets have an id, use that as tie breaker
|
|
|
|
// since that's the order in which autowithdrawals are attempted
|
|
|
|
if (w1.config?.id && w2.config?.id) return Number(w1.config.id) - Number(w2.config.id)
|
|
|
|
|
|
|
|
// else we will use the card title as tie breaker
|
2024-10-23 17:42:34 +00:00
|
|
|
return w1.def.card.title < w2.def.card.title ? -1 : 1
|
|
|
|
}
|
|
|
|
|
|
|
|
export function isServerField (f) {
|
|
|
|
return f.serverOnly || !f.clientOnly
|
|
|
|
}
|
|
|
|
|
|
|
|
export function isClientField (f) {
|
|
|
|
return f.clientOnly || !f.serverOnly
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkFields ({ fields, config }) {
|
|
|
|
// a wallet is configured if all of its required fields are set
|
|
|
|
let val = fields.every(f => {
|
2024-10-25 19:10:37 +00:00
|
|
|
if (f.optional && !f.requiredWithout) return true
|
|
|
|
return !!config?.[f.name]
|
2024-10-23 17:42:34 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
// however, a wallet is not configured if all fields are optional and none are set
|
|
|
|
// since that usually means that one of them is required
|
|
|
|
if (val && fields.length > 0) {
|
|
|
|
val = !(fields.every(f => f.optional) && fields.every(f => !config?.[f.name]))
|
|
|
|
}
|
|
|
|
|
|
|
|
return val
|
|
|
|
}
|
|
|
|
|
2024-10-24 20:30:56 +00:00
|
|
|
export function isConfigured ({ def, config }) {
|
|
|
|
return isSendConfigured({ def, config }) || isReceiveConfigured({ def, config })
|
2024-10-23 17:42:34 +00:00
|
|
|
}
|
|
|
|
|
2024-10-24 20:30:56 +00:00
|
|
|
function isSendConfigured ({ def, config }) {
|
|
|
|
const fields = def.fields.filter(isClientField)
|
|
|
|
return checkFields({ fields, config })
|
2024-10-23 17:42:34 +00:00
|
|
|
}
|
|
|
|
|
2024-10-24 20:30:56 +00:00
|
|
|
function isReceiveConfigured ({ def, config }) {
|
|
|
|
const fields = def.fields.filter(isServerField)
|
|
|
|
return checkFields({ fields, config })
|
2024-10-23 17:42:34 +00:00
|
|
|
}
|
|
|
|
|
2024-10-24 20:30:56 +00:00
|
|
|
export function canSend ({ def, config }) {
|
|
|
|
return !!def.sendPayment && isSendConfigured({ def, config })
|
2024-10-23 17:42:34 +00:00
|
|
|
}
|
|
|
|
|
2024-10-24 20:30:56 +00:00
|
|
|
export function canReceive ({ def, config }) {
|
2024-10-25 19:10:37 +00:00
|
|
|
return def.fields.some(f => f.serverOnly) && isReceiveConfigured({ def, config })
|
2024-10-23 00:53:56 +00:00
|
|
|
}
|