Prerequisites
Required setup's before setting up SurfSense
PGVector installation Guide
SurfSense requires the pgvector extension for PostgreSQL:
Linux and Mac
Compile and install the extension (supports Postgres 13+)
See the installation notes if you run into issues
Windows
Ensure C++ support in Visual Studio is installed, and run:
Note: The exact path will vary depending on your Visual Studio version and edition
Then use nmake
to build:
See the installation notes if you run into issues
Google OAuth Setup (Optional)
SurfSense supports both Google OAuth and local email/password authentication. Google OAuth is optional - if you prefer local authentication, you can skip this section.
To set up Google OAuth:
- Login to your Google Developer Console
- Enable People API.
- Set up OAuth consent screen.
- Create OAuth client ID and secret.
- It should look like this.
File Upload's
SurfSense supports two ETL (Extract, Transform, Load) services for converting files to LLM-friendly formats:
Option 1: Unstructured
Files are converted using Unstructured
- Get an Unstructured.io API key from Unstructured Platform
- You should be able to generate API keys once registered
Option 2: LlamaIndex (LlamaCloud)
Files are converted using LlamaIndex which offers 50+ file format support.
- Get a LlamaIndex API key from LlamaCloud
- Sign up for a LlamaCloud account to access their parsing services
- LlamaCloud provides enhanced parsing capabilities for complex documents
Note: You only need to set up one of these services.
LLM Observability (Optional)
This is not required for SurfSense to work. But it is always a good idea to monitor LLM interactions. So we do not have those WTH moments.
- Get a LangSmith API key from smith.langchain.com
- This helps in observing SurfSense Researcher Agent.
Crawler
SurfSense have 2 options for saving webpages:
- SurfSense Extension (Overall better experience & ability to save private webpages, recommended)
- Crawler (If you want to save public webpages)
NOTE: SurfSense currently uses Firecrawl.py for web crawling. If you plan on using the crawler, you will need to create a Firecrawl account and get an API key.
Next Steps
Once you have all prerequisites in place, proceed to the installation guide to set up SurfSense.