Generate validation schema for LnAddr

This commit is contained in:
ekzyis 2024-07-17 02:48:46 +02:00
parent 587bfa34be
commit 4df0b460c3
3 changed files with 11 additions and 19 deletions

View File

@ -149,7 +149,7 @@ const nameValidator = string()
const intValidator = number().typeError('must be a number').integer('must be whole')
const floatValidator = number().typeError('must be a number')
const lightningAddressValidator = process.env.NODE_ENV === 'development'
export const lightningAddressValidator = process.env.NODE_ENV === 'development'
? string().or(
[string().matches(/^[\w_]+@localhost:\d+$/), string().email()],
'address is no good')
@ -303,17 +303,6 @@ export function advSchema (args) {
})
}
export function lnAddrAutowithdrawSchema ({ me } = {}) {
return object({
address: lightningAddressValidator.required('required').test({
name: 'address',
test: addr => !addr.endsWith('@stacker.news'),
message: 'automated withdrawals must be external'
}),
...autowithdrawSchemaMembers
})
}
export function CLNAutowithdrawSchema ({ me } = {}) {
return object({
socket: string().socket().required('required'),

View File

@ -1,5 +1,5 @@
import { array, object, string } from 'yup'
import { autowithdrawSchemaMembers, hexOrBase64Validator } from '@/lib/validate'
import { autowithdrawSchemaMembers, hexOrBase64Validator, lightningAddressValidator } from '@/lib/validate'
import { TOR_REGEXP } from '@/lib/url'
export function generateResolverName (walletField) {
@ -25,7 +25,7 @@ export function generateSchema (wallet) {
let validator
const stringTypes = ['url', 'string']
const stringTypes = ['url', 'string', 'email']
if (stringTypes.includes(validationType)) {
validator = string()
@ -57,6 +57,8 @@ export function generateSchema (wallet) {
})
}
if (validationType === 'email') validator = lightningAddressValidator
if (words) {
validator = array()
.transform(function (value, originalValue) {

View File

@ -1,5 +1,3 @@
import { lnAddrAutowithdrawSchema } from '@/lib/validate'
export const name = 'lightning-address'
export const shortName = 'lnAddr'
@ -8,7 +6,12 @@ export const fields = [
name: 'address',
label: 'lightning address',
type: 'text',
autoComplete: 'off'
autoComplete: 'off',
validate: {
type: 'email',
test: addr => !addr.endsWith('@stacker.news'),
message: 'automated withdrawals must be external'
}
}
]
@ -18,8 +21,6 @@ export const card = {
badges: ['receive only', 'non-custodialish']
}
export const schema = lnAddrAutowithdrawSchema
export const walletType = 'LIGHTNING_ADDRESS'
export const walletField = 'walletLightningAddress'