stacker.news/wallets/common.js

99 lines
3.1 KiB
JavaScript
Raw Normal View History

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
}