简体中文 · English
- V0.2.6, 20240425, support the searxng search service, support the moonshot API in stream mode
- V0.2.5, 20240425, open source the code for the search api
- V0.2.4, 20240424, support for Groq in Cloudflare Worker
- V0.2.3, 20240423, support for Azure OpenAI in Cloudflare Worker. It also introduces the ability to use an authorization code and customize the user's request key.
- V0.2.2, 20240420, support Moonshot API on unstream mode
- V0.2.1, 20240310, supports Google, Bing, Duckduckgo, Search1API for news-type searches; supports adjusting the number of search results via the MAX_RESULTS environment variable; supports adjusting the number of in-depth searches desired via the CRAWL_RESULTS environment variable.
- V0.2.0,20240310,Optimized openai.js, cloudflare worker version, really faster this time!
For more historical updates, please see Version History
Help your LLM API support networking, search, news, web page summarization, has supported OpenAI, Gemini, Moonshot, the big model will be based on your input to determine whether the network, not every time the network search, do not need to install any plug-ins, do not need to replace the key, directly in your commonly used OpenAI/Gemini three-way client replacement of custom You can directly replace the customized address in your usual OpenAI/Gemini three-way client, and also support self-deployment, which will not affect the use of other functions, such as drawing, voice, etc.
Model | Features | Stream | Deployments |
---|---|---|---|
OpenAI |
search, news, crawler | stream, unstream | Zeabur, Local deployment, Cloudflare Worker, Vercel |
Azure OpenAI |
search, news, crawler | stream, unstream | Cloudflare Worker |
Groq |
search, news, crawler | stream, unstream | Cloudflare Worker |
Gemini |
search | stream, unstream | Cloudflare Worker |
Moonshot |
search, news, crawler | stream(only on cf), unstream | Zeabur, Local deployment, Cloudflare Worker(stream), Vercel |
Replace the custom domain in any client with the following address
Zeabur
Click the button for one-click deployment, switched on your own environment variables
To keep the project updated, it is recommended to fork this repository first, then deploy your branch through Zeabur
Local Deployment
- Clone the repository locally
git clone https://github.com/fatwang2/search2ai
- Copy .env.template as .env, configure environment variables
- Enter the api directory, run the program, and display the log in real-time
cd api && nohup node index.js > output.log 2>&1 & tail -f output.log
- Port 3014, the complete address after concatenation is as follows, can be configured according to the client's requirements for the apibase address (if https is required, need to use nginx for reverse proxy, many tutorials online)
http://localhost:3014/v1/chat/completions
Cloudflare worker
- Copy the code of search2openai.js, or search2gemini.js, or search2groq.js, no modifications needed! Deploy in cloudflare's worker, after going online, the worker's address can be used as your interface call's custom domain address, note the concatenation, worker address only represents the part before v1
- Configure variables in the worker(only openai)
- Configure triggers - custom domain in the worker, direct access to the worker's address in China might have issues, need to replace with custom domain
Vercel
Special note: Vercel project does not support streaming output and has a 10s response limit, actual user experience is poor, released mainly for experts to pull request
One-click deployment
To ensure updates, you can also first fork this project and then deploy it on Vercel yourself
This project provides some additional configuration options, which can be set through environment variables:
Environment Variable | Required | Description | Example |
---|---|---|---|
SEARCH_SERVICE |
Yes | Your search service. The key of the service you choose needs to be configured. | search1api, google, bing, serpapi, serper, duckduckgo, searxng |
APIBASE |
No | Third-party proxy address. | https://api.openai.com, https://api.moonshot.cn, https://api.groq.com/openai |
MAX_RESULTS |
Yes | Number of search results. | 10 |
CRAWL_RESULTS |
No | The number of deep searches (retrieve the main text of the webpage after searching). Currently only supports search1api, deep search will be slow. | 1 |
SEARCH1API_KEY |
No | Required if using search1api. Fast and affordable search service I built. Click here to register | xxx |
BING_KEY |
No | Required if using Bing search. Please search for tutorials. Click here to create | xxx |
GOOGLE_CX |
No | Required if using Google search. Search engine ID. Please search for tutorials. Click here to create | xxx |
GOOGLE_KEY |
No | Required if using Google search. API key. Click here to create | xxx |
SERPAPI_KEY |
No | Required if using serpapi. Free 100 requests/month. Click here to register | xxx |
SERPER_KEY |
No | Required if using serper. Free 2500 requests for 6 months. Click here to register | xxx |
SEARXNG_BASE_URL |
No | Required if using searxng. Fill in your self-hosted searXNG service domain. JSON mode must be enabled. Tutorial: link | https://search.xxx.xxx |
OPENAI_TYPE |
No | OpenAI provider source, default is openai | openai, azure |
RESOURCE_NAME |
Conditional | Required if azure is selected | xxxx |
DEPLOY_NAME |
Conditional | Required if azure is selected | gpt-35-turbo |
API_VERSION |
Conditional | Required if azure is selected | 2024-02-15-preview |
AZURE_API_KEY |
Conditional | Required if azure is selected | xxxx |
AUTH_KEYS |
No | If you want users to define a separate authorization code as a key when making requests, you need to fill this in. Required if azure is selected | 000,1111,2222 |
OPENAI_API_KEY |
No | If you want users to define a separate authorization code as a key when requesting openai, you need to fill this in | sk-xxx |
- Fix streaming output issues in Vercel project
- Improve the speed of streaming output
- Support more vertical searches