Utilizing AI for web scraping in Salesforce
Table of Contents
TL;DR:
Learn how to create a powerful competitor analysis tool by combining Salesforce with web scraping (Firecrawl) and AI using GPTfy.
With a few hours of work and minimal code, you can automatically extract and analyze competitor website data directly within your Salesforce opportunities.
Not a fan of reading articles? Check out the video here:

What?
A plain English guide on building a competitor analysis tool in Salesforce that automatically scrapes and analyzes competitor websites. We’ll cover integrating web scraping APIs, configuring GPTfy, and using AI to generate insights – all with minimal code.
Who?
Salesforce admins, developers, solution architects, and business analysts who want to enhance their CRM with automated competitive intelligence capabilities.
Why?
To help your sales team with instant competitive insights.
-> Improve win rates. Make data-driven decisions. Save hours of manual research.
What can you do with it?
Automated Competitor Analysis: Extract and analyze competitor website data directly within Salesforce opportunities
Real-time Intelligence: Get instant comparisons and insights when opportunity competitors change
Customizable Insights: Configure AI prompts to focus on specific competitive areas important to your business
1. Setting Up the Foundation: Salesforce + Firecrawl Integration
The integration starts with Firecrawl, a web scraping API service. Here’s the setup process:
- Sign up for a Firecrawl trial account and get API keys
- Create a Remote Site Setting in Salesforce to allow API calls
- Use ChatGPT/Claude to generate basic Apex classes for API integration
- Add custom fields to Opportunity for competitor websites
GPTfy’s API Data Source feature makes this integration seamless and mostly declarative.
Firecrawl API Data Source Code
global class firecrawlMasterDataSource implements ccai.AIDataSourceInterface {
global String getExternalData(ccai_AI_Data_Source_c dataSource, String extractedData) {
try {
// Parse the extracted data to retrieve website URLs
System.debug('Extracted Data (Raw Input): ' + extractedData);
Map inputData = (Map) JSON.deserializeUntyped(extractedData);
String url1 = (String) inputData.get('CompetitorWebSite1__c');
String url2 = (String) inputData.get('CompetitorWebSite2__c');
// Validate URLs
if (String.isBlank(url1) || String.isBlank(url2)) {
throw new IllegalArgumentException('One or both competitor websites are missing.');
}
// Fetch data from FirecrawlService
Map combinedData = makeCallouts(url1, url2);
// Return the combined data as a JSON string
return JSON.serializePretty(combinedData);
} catch (Exception e) {
System.debug('Error: ' + e.getMessage());
throw new CustomException('Error processing external data: ' + e.getMessage());
}
}
// Helper method for making callouts
private Map makeCallouts(String url1, String url2) {
FirecrawlService.FirecrawlResponse response1 = FirecrawlService.fetchWebsiteData(url1);
FirecrawlService.FirecrawlResponse response2 = FirecrawlService.fetchWebsiteData(url2);
// Convert responses to Strings and trim to 5000 characters
String response1Data = response1 != null && response1.data != null
? String.valueOf(response1.data).substring(0, Math.min(String.valueOf(response1.data).length(), 5000))
: null;
String response2Data = response2 != null && response2.data != null
? String.valueOf(response2.data).substring(0, Math.min(String.valueOf(response2.data).length(), 5000))
: null;
// Combine the results into a single structure
Map combinedData = new Map();
combinedData.put('Website1Data', response1Data);
combinedData.put('Website2Data', response2Data);
System.debug('Trimmed Combined Data: ' + JSON.serializePretty(combinedData));
return combinedData;
}
// Define a custom exception to replace ccai.AIDataSourceException
global class CustomException extends Exception {}
}
2. Configuring GPTfy for Web Scraping
GPTfy acts as the bridge between Salesforce, Firecrawl, and AI:
- Create an API Data Source in GPTfy specifying your connector class
- Configure data mapping to include relevant Opportunity fields
- Set up field mappings for competitor website fields
- Choose your preferred AI model and adjust settings like temperature
The beauty is that most of this is declarative – you only need Apex for the initial API connection.
Bring Any AI Models to Your Salesforce
Handle questions securely with AI. Works with Pro, Enterprise & Unlimited - your data never leaves Salesforce.
Get GPTfyRead More here3. Crafting AI Prompts for Competitive Analysis
The final piece is creating effective prompts that turn raw website data into actionable insights:
- Design prompts that extract key competitive information
- Configure formatting for easy readability
- Use AI to help refine and optimize your prompts
- Test and iterate based on results
Prompt for Website Comparison in Salesforce
Objective: Analyze and compare two websites based on provided JSON data, highlighting key differences and similarities.
Input: JSON containing scraped website content from two companies, including HTML structure and metadata.
Requirements:
1. Extract and identify:
- Company names from metadata, URLs, or titles
- Main navigation elements
- Content focus and purpose
- Design elements and layout
- Target audience indicators
- Special features or functionalities
2. Formatting:
- Use proper company names throughout
- Organize comparison by category
- Highlight direct contrasts
- Include specific examples
- Note unique features
3. Structure Analysis As:
- Primary Purpose/Focus
- Navigation Structure
- Content Organization
- User Experience Elements
- Distinguishing Features
4. Maintain Clarity:
- Use concise language
- Provide specific examples
- Avoid technical jargon
- Focus on meaningful differences
Output Format:
[Company1] vs [Company2]: A Feature Analysis
Primary Focus:
- [Company1]: [Main purpose/focus]
- [Company2]: [Main purpose/focus]
Key Differentiators:
1. Navigation & Structure
2. Content Approach
3. User Experience
4. Special Features
Unique Strengths:
- [Company1]: [List key advantages]
- [Company2]: [List key advantages]
Pro tip: Use AI to help write and refine your prompts by showing it sample data and desired outputs.
Conclusion
Building a powerful competitor analysis tool doesn’t have to be complex or time-consuming. By combining Salesforce, Firecrawl, and GPTfy, you can create an automated solution in just a few hours – even with minimal coding experience.
The power lies in the combination of Salesforce’s CRM capabilities, Firecrawl’s web scraping capabilities, and AI’s analysis capabilities, all orchestrated seamlessly by GPTfy.
This approach demonstrates how quickly you can go from idea to working prototype using modern AI tools.
Additional Resources
- Calculate Salesforce + AI ROI here
- Check out GPTfy Knowledge Base
- Check out other Salesforce + AI Use Cases
- Watch the Salesforce + AI Use Cases Demo
- Check out the GPTfy Blog for more blogs on Salesforce + AI

Kalanithi Balasubramanian
Kalanithi is a Senior Salesforce Engineer specializing in AppExchange solutions, AI-driven integrations, and workflow automation, with a track record of enhancing enterprise efficiency through LLM-powered innovations.
Blogs you may find interesting

How to Create Knowledge Articles from Cases Solved in Salesforce?
See how AI can create Knowledge Articles from Cases Solved in Salesforce

Integrate Deepseek into Salesforce with GPTfy
Learn how AI can do Apex Code Reviews in Salesforce

Automate Apex Code Reviews in Salesforce with AI using GPTfy
Learn how AI can do Apex Code Reviews in Salesforce

Navigating Commercial Realities & Internal Dynamics
Understand the key factors that can impact your Salesforce AI project

Making It Work – Salesforce + AI From Pilot to Production
Move from AI planning to real-world implementation in your Salesforce environment

Keep AI Safe and Secure in Your Salesforce Enterprise: A Practical Guide
Guide to implement AI securely in your Salesforce

How Salesforce + AI Can Drive Real Business Value in Your Enterprise
Find out how you can improve your business with AI in Salesforce.

Open AI or Google Vertex Which is better for your AI + Salesforce
Find out what AI model makes sense for your Salesforce?

How to Bring Llama AI into Your Salesforce
Connect Llama, Meta’s Open-source AI model, to your Salesforce with GPTfy

Prompt Grounding in Salesforce: Keep AI Sane!
Learn how to add grounding rules to your Salesforce AI prompts.

Transforming Admissions with AI and Salesforce
Learn how to use AI in the student lifecycle from inquiry to enrollment and beyond.

Put your Data to work with Salesforce+AI
Find out how you can bring external and internal data to give more context to AI in Salesforce.