Infrastructure
Ask question → Get answer with sources → Click through to source
Watch it on Youtube
Teams using SWIRL saves an average 7.5 hours of productive time per week.
❌ Without SWIRL
|
✅ With SWIRL
|
# No need for:
$ setup-vector-db
$ migrate-data
$ configure-indexes
# Just this:
$ curl https://raw.githubusercontent.com/swirlai/swirl-search/main/docker-compose.yaml -o docker-compose.yaml
Real examples of what teams build with SWIRL:
Try SWIRL Enterprise for free for 30 Days. Click on the banner to contact us.
SWIRL doesn't just search - it understands your company's context. Instead of broad web results, you get precise answers from your private data, right where it lives.
For Support on Connectors Contact the Swirl Team at: support@swirlaiconnect.com
To run Swirl in Docker, you must have the latest Docker app for MacOS, Linux, or Windows installed and running locally. You can also watch the video tutorial to get started.
Windows users must also install and configure either the WSL 2 or the Hyper-V backend, as outlined in the System Requirements for installing Docker Desktop on Windows.
Warning Make sure the Docker app is running before proceeding!
curl https://raw.githubusercontent.com/swirlai/swirl-search/main/docker-compose.yaml -o docker-compose.yaml
export MSAL_CB_PORT=8000
export MSAL_HOST=localhost
export OPENAI_API_KEY=‘<your-OpenAI-API-key>’
:key: Check out OpenAI's YouTube video if you don't have an OpenAI API Key.
docker-compose pull && docker-compose up
docker compose up
After a few minutes the following or similar should appear:
Open this URL with a browser: http://localhost:8000 (or http://localhost:8000/galaxy)
If the search page appears, click Log Out
at the top, right. The Swirl login page will appear.
Enter the username admin
and password password
, then click Login
.
Enter a search in the search box and press the Search
button. Ranked results appear in just a few seconds:
The most recent Search object will be displayed at the top. Click on the result_url
link to view the full JSON Response.
Warning The Docker version of Swirl does not retain any data or configuration when shut down!
:key: Swirl includes five (5) Google Programmable Search Engines (PSEs) to get you up and running right away. The credentials for these are shared with the Swirl Community.
:key: Using Swirl with Microsoft 365 requires installation and approval by an authorized company Administrator. For more information, please review the M365 Guide or contact us.
Check out the details of our latest release!
Head over to the Quick Start Guide and install Swirl locally!
Guide to Run SWIRL in Docker in 60 seconds.
✦ | Feature |
---|---|
📌 | Microsoft 365 integration and OAUTH2 support |
🔍 | SearchProvider configurations for all included Connectors. They can be organized with the active, default and tags properties. |
✏️ | Adaptation of the query for each provider such as rewriting NOT term to -term , removing NOTted terms from providers that don't support NOT, and passing down the AND, + and OR operators. |
⏳ | Synchronous or asynchronous search federation via APIs |
🛎️ | Optional subscribe feature to continuously monitor any search for new results |
🛠️ | Pipelining of Processor stages for real-time adaptation and transformation of queries, responses and results |
🗄️ | Results stored in SQLite3 or PostgreSQL for post-processing, consumption and/or analytics |
➡️ | Built-in Query Transformation support, including re-writing and replacement |
📖 | Matching on word stems and handling of stopwords via NLTK |
🚫 | Duplicate detection on field or by configurable Cosine Similarity threshold |
🔄 | Re-ranking of unified results using Cosine Vector Similarity based on spaCy's large language model and NLTK |
🎚️ | Result mixers order results by relevancy, date or round-robin (stack) format, with optional filtering of just new items in subscribe mode |
📄 | Page through all results requested, re-run, re-score and update searches using URLs provided with each result set |
📁 | Sample data sets for use with SQLite3 and PostgreSQL |
✒️ | Optional spell correction using TextBlob |
⌛ | Optional search/result expiration service to limit storage use |
🔌 | Easily extensible Connector and Mixer objects |
Do you have a brilliant idea or improvement for SWIRL? We're all ears, and thrilled you're here to help!
🔗 Get Started in 3 Easy Steps:
develop
branch with a descriptive name that encapsulates your idea or fix.develop
branch.📚 First time contributing on GitHub? No worries, the GitHub documentation has you covered with a great guide on contributing to projects.
💡 Every contribution, big or small, makes a difference. Join us in shaping the future of Swirl!
For information about Swirl as a managed service, please contact us!
At Swirl, every user matters to us. Whether you're a beginner finding your way or an expert with feedback, we're here to support, listen, and help. Don't hesitate to reach out to us.
Join the SWIRL Community Slack: Dive into our SWIRL Community on Slack - to discuss anything related to SWIRL.
Direct Support: For any questions, suggestions, or even a simple hello, drop us an email at support@swirlaiconnect.com. We cherish every message and promise to get back to you promptly!
Request A Connector (Enterprise Support) Want to see a new connector quickly and fast. Contact the Swirl Team at: support@swirlaiconnect.com