2021-07-11 22:58:17 -04:00

66 lines
2.2 KiB
TypeScript

import { BigcommerceApiError } from '../../utils/errors'
import type { ChangePasswordEndpoint } from '.'
const changePassword: ChangePasswordEndpoint['handlers']['changePassword'] = async ({
res,
body: { email, currentPassword, newPassword },
config,
commerce
}) => {
// // TODO: Add proper validations with something like Ajv
// if (!(email && password)) {
// return res.status(400).json({
// data: null,
// errors: [{ message: 'Invalid request' }]
// })
// }
// // TODO: validate the password and email
// // Passwords must be at least 7 characters and contain both alphabetic
// // and numeric characters.
//
// try {
// await config.storeApiFetch('/v3/customers', {
// method: 'POST',
// body: JSON.stringify([
// {
// first_name: firstName,
// last_name: lastName,
// email,
// authentication: {
// new_password: password
// }
// }
// ])
// })
// } catch (error) {
// if (error instanceof BigcommerceApiError && error.status === 422) {
// const hasEmailError = '0.email' in error.data?.errors
//
// // If there's an error with the email, it most likely means it's duplicated
// if (hasEmailError) {
// return res.status(400).json({
// data: null,
// errors: [
// {
// message: 'The email is already in use',
// code: 'duplicated_email'
// }
// ]
// })
// }
// }
//
// throw error
// }
//
// // Login the customer right after creating it
// await commerce.login({ variables: { email, password }, res, config })
const supplied = `YOU SUPPLIED: "${email}" "${currentPassword}" "${newPassword}"`
console.log(supplied);
res.status(200).json({ data: null, errors: [{message: supplied }] })
}
export default changePassword