index.ts•2.56 kB
import { createPiece, PieceAuth } from '@activepieces/pieces-framework';
import { googleNewsSearch } from './lib/actions/google-news-search';
import { googleSearch } from './lib/actions/google-search';
import { googleTrendsSearch } from './lib/actions/google-trends-search';
import { youtubeSearch } from './lib/actions/youtube-search';
import { SerpApiClient } from './lib/services/serp-api-client';
import { SerpApiValidator } from './lib/utils/validators';
export const serpApiAuth = PieceAuth.SecretText({
displayName: 'API Key',
description: `You can obtain your API key from [Dashboard](https://serpapi.com/dashboard).`,
required: true,
validate: async ({ auth }) => {
try {
// Validate API key format first
const formatValidation = SerpApiValidator.validateApiKey(auth);
if (!formatValidation.isValid) {
return {
valid: false,
error: `Invalid API key format: ${formatValidation.errors.join(', ')}`,
};
}
// Test API key with actual request
const client = new SerpApiClient({
defaultTimeout: 10000,
defaultRetries: 1,
});
const isValid = await client.validateApiKey(auth);
if (!isValid) {
return {
valid: false,
error: 'Invalid API key. Please check your SerpApi API key and ensure it has sufficient credits.',
};
}
return {
valid: true,
};
} catch (error) {
const errorMessage = error instanceof Error ? error.message : 'Unknown error occurred';
if (errorMessage.includes('timeout')) {
return {
valid: false,
error: 'API validation timed out. Please check your network connection and try again.',
};
}
if (errorMessage.includes('network') || errorMessage.includes('ENOTFOUND')) {
return {
valid: false,
error: 'Network error occurred. Please check your internet connection.',
};
}
return {
valid: false,
error: `API key validation failed: ${errorMessage}`,
};
}
},
});
export const serpApi = createPiece({
displayName: 'SerpApi',
description: 'Search Google, YouTube, News, and Trends with powerful filtering and analysis capabilities',
auth: serpApiAuth,
minimumSupportedRelease: '0.36.1',
logoUrl: 'https://cdn.activepieces.com/pieces/serp-api.png',
authors: ['AnkitSharmaOnGithub'],
actions: [
googleSearch,
googleNewsSearch,
youtubeSearch,
googleTrendsSearch,
],
triggers: [],
});