auth.ts•1.12 kB
import { PieceAuth } from '@activepieces/pieces-framework';
import { getCampaigns } from './api';
import { z } from 'zod';
import { propsValidation } from '@activepieces/pieces-common';
export type BonjoroAuthType = { apiKey: string };
export const bonjoroAuth = PieceAuth.CustomAuth({
description: 'Authenticate with your Bonjoro account',
props: {
apiKey: PieceAuth.SecretText({
displayName: 'API Key',
description: 'The API key for your Bonjoro account',
required: true,
}),
},
validate: async ({ auth }) => {
try {
await propsValidation.validateZod(auth, {
apiKey: z.string().min(1),
});
await validateAuth(auth);
return {
valid: true,
};
} catch (e) {
return {
valid: false,
error: (e as Error)?.message,
};
}
},
required: true,
});
const validateAuth = async (auth: BonjoroAuthType) => {
const response = await getCampaigns(auth);
if (response.success !== true) {
throw new Error(
'Authentication failed. Please check your domain and API key and try again.'
);
}
};