Signup working with new db

This commit is contained in:
metacryst
2025-11-23 22:16:53 -06:00
parent c3ed5ac5ac
commit 8c7ed68975
8 changed files with 98 additions and 67 deletions

View File

@@ -1,11 +1,33 @@
import OrderedObject from "./OrderedObject.js"
const argon2 = require("argon2")
const { z } = require("zod")
export default class Members extends OrderedObject {
addressSchema = z.object({
address1: z.string(),
address2: z.string().optional(),
zip: z.string().regex(/^\d{5}(-\d{4})?$/),
state: z.string(),
city: z.string()
})
schema = z.object({
email: z.string().email(),
firstName: z.string(),
lastName: z.number().int().min(0),
password: z.string(),
address: this.addressSchema
})
add(newMember) {
isHashed = (s) => {return s.startsWith("$argon2")}
async add(newMember) {
console.log("adding ", newMember)
let id = `MEMBER-${newMember.email}`
if(this.validate(id, newMember)) {
if(this.schema.safeParse(newMember)) {
if(!this.isHashed(newMember.password)) {
const hash = await argon2.hash(newMember.password);
newMember.password = hash
}
try {
super.add(id, newMember)
} catch(e) {
@@ -17,48 +39,7 @@ export default class Members extends OrderedObject {
}
}
validate(id, node) {
let idTraits = {
firstWord: "MEMBER"
}
let fields = [
"firstName",
"lastName",
"email",
"password"
]
let checkID = () => {
let split = id.split("-")
return (
split[0] === idTraits.firstWord
&& split[1].includes("@")
&& split[1].includes(".")
)
}
let idres = checkID()
if(!idres) {
console.log("id failed: ", id)
return false
}
let checkFields = () => {
for(let i = 0; i < fields.length; i++) {
if(!node[fields[i]]) {
throw new Error(`Member ${node.email} is missing trait ${fields[i]}`)
return false
} else {
return true
}
}
}
let fieldres = checkFields()
if(!fieldres) {
console.log("fields failed")
return false
}
return true
getByEmail(email) {
return super.get(`MEMBER-${email}`)
}
}