vendure-phone-auth-plugin
v1.0.2
Published
A Vendure plugin which adds phone authentication to the storefront
Downloads
30
Readme
Vendure Phone Auth Plugin
This plugin adds phone authentication to the Vendure GraphQL API.
Installation
yarn add vendure-phone-auth-plugin
Usage
Backend
import { PhoneAuthPlugin } from "vendure-phone-auth-plugin";
export const config: VendureConfig = {
// ...
plugins: [
// ...
PhoneAuthPlugin.init({
sendOtp: async (phone, otp) => {
Logger.info(`${otp} sent to ${phone}`, "PhoneAuthPlugin");
try {
await thirdPartySms(otp, phone);
return Promise.resolve(true);
} catch (error) {
return Promise.resolve(false);
}
},
defaultUserDataBuilder(phone) {
return {
emailAddress: `${phone}@example.com`, // you can use your own logic here
firstName: "",
lastName: "",
};
},
// you can config otp generator here
otpGeneratorOptions?: {
length?: number; // required
upperCaseAlphabets?: boolean;
specialChars?: boolean;
digits?: boolean;
lowerCaseAlphabets?: boolean;
}
}),
],
};
Frontend
gql`
mutation requestOtp($phone: String!) {
requestOtp(phone: $phone)
}
`;
gql`
mutation PhoneAuthenticate($phone: String!, $otp: String!) {
authenticate(input: { phone: { phone: $phone, otp: $otp } }) {
__typename
... on CurrentUser {
id
identifier
}
... on ErrorResult {
errorCode
message
}
}
}
`;