petercat
  <h1 align="center"> PeterCat</h1> <div align="center"> <img src="https://gw.alipayobjects.com/zos/antfincdn/R8sN%24GNdh6/language.svg" width="18"> 简体中文 | [English](./README.en-US.md) | [日本語](./README.ja-JP.md) **专为社区维护者和开发者打造的智能答疑机器人解决方案。** [](https://www.npmjs.com/package/@petercatai/assistant) [](https://www.npmjs.com/package/petercat-lui) [](https://hub.docker.com/r/petercatai/petercat) [](https://github.com/petercat-ai/petercat/actions/workflows/pr-tests.yml) [](https://codecov.io/github/petercat-ai/petercat) [](https://github.com/petercat-ai/petercat/blob/master/LICENSE) </div> ## 🏠 主页 [🐱 窝: petercat.ai](https://petercat.ai) ## ✨ 特性 我们提供对话式答疑 Agent 配置系统、自托管部署方案和便捷的一体化应用 SDK,让您能够为自己的 GitHub 仓库一键创建智能答疑机器人,并快速集成到各类官网或项目中, 为社区提供更高效的技术支持生态。 ### 对话即创造 仅需要告知你的仓库地址或名称,PeterCat 即可自动完成创建机器人的全部流程  ### 知识自动入库 机器人创建后,所有相关 Github 文档和 issue 将自动入库,作为机器人的知识依据  ### 多平台集成 多种集成方式自由选择,如对话应用 SDK 集成至官网,Github APP 一键安装至 Github 仓库等 |  |  | | :-: | :-: | [完整演示视频](https://www.bilibili.com/video/BV1KiHUeFE4p) ### 不止是 QA 机器人 | 项目信息查询 | 回复 Discussion | | --- | --- | |  |  | | PR Summary | Code Review | | --- | --- | |  |  | | | 查 Issue | 提 Issue | 回 Issue | | --- | --- | --- | |  |  |  | [完整演示视频](https://www.bilibili.com/video/BV12eHUe8EkT/) ## Agent 工作流 我们为猫猫预置了一个创建机器人的机器人,当得到用户 GitHub 仓库地址或名称时,它会使用创建工具,生成该仓库答疑机器人的各项配置(Prompt,、名字、 头像、开场白、引导语、工具集……),同时触发 Issue 和 Markdown 的入库任务。这些任务会拆分为多个子任务,将该仓库的所有已解决 issue 、高票回复以及所有 Markdown 文件内容经过 load -> split -> embed -> store 的加工过程进行知识库构建,作为机器人的回复知识依据。  ## 📦 私有化部署 部署方案:[AWS](https://aws.amazon.com) + [Supabase](https://supabase.com) 你可以在这里看到完整方案: - [私有化部署 - 本地启动服务](./docs/guides/self_hosted_local_cn.md) - [私有化部署 - 部署到 AWS ](./docs/guides/self_hosted_aws_cn.md)  [](https://www.youtube.com/watch?v=Al6R9Ye5mBY) ## ⚙️ 环境变量 本项目需要进行环境变量进行设置: ### Client `.env.local` | 环境变量 | 类型 | 描述 | 示例 | | --- | --- | --- | --- | | `NEXT_PUBLIC_API_DOMAIN` | 必选 | 后端服务的 API 域名。 | `https://api.petercat.ai` | ### Server `.env` | 环境变量 | 类型 | 描述 | 示例 | | --- | --- | --- | --- | | **应用基础环境变量** | | `API_URL` | 必选 | 后端服务的 API 域名 | `https://api.petercat.ai` | | `WEB_URL` | 必选 | 前端 Web 服务的域名 | `https://petercat.ai` | | `STATIC_URL` | 必选 | 静态资源域名 | `https://static.petercat.ai` | | **AWS 相关环境变量** | | `X_GITHUB_SECRET_NAME` | 必选 | AWS 托管的 Github 私钥文件名 | `prod/githubapp/petercat/pem` | | `STATIC_SECRET_NAME` | 可选 | AWS 托管的 CloudFront 签名私钥名称。如果配置了该项,将使用 CloudFront 签名 URL 来保护你的资源。更多信息请参阅 [AWS 文档](https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-trusted-signers.html)。 | `prod/petercat/static` | | `LLM_TOKEN_SECRET_NAME` | 可选 | AWS 托管的 llm 签名私钥名称。如果配置了该项,petercat 将使用 RSA 算法托管用户的 LLM Token | `prod/petercat/llm` | | `LLM_TOKEN_PUBLIC_NAME` | 可选 | AWS 托管的 llm 签名公钥名称。如果配置了该项,petercat 将使用 RSA 算法托管用户的 LLM Token | `prod/petercat/llm/pub` | | `STATIC_KEYPAIR_ID` | 可选 | AWS CloudFront 的 Key Pair ID。如果配置了该项,将使用 CloudFront 签名 URL 来保护你的资源。更多信息请参阅 [AWS 文档](https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-trusted-signers.html)。 | `APKxxxxxxxx` | | `S3_TEMP_BUCKET_NAME` | 可选 | 用于托管 AWS 临时图片文件 S3 的 bucket | `xxx-temp` | | **SUPABASE 相关 env** | | `SUPABASE_URL` | 必选 | supabase 服务的 URL,可以在[这里](https://supabase.com/dashboard/project/_/settings/database)找到 | `https://***.supabase.co` | | `SUPABASE_SERVICE_KEY` | 必选 | supabase 服务密钥,可以在[这里](https://supabase.com/dashboard/project/_/settings/database)找到 | `{{SUPABASE_SERVICE_KEY}}` | | **Auth0 相关 env** | | `AUTH0_DOMAIN` | 必选 | auth0 服务域名,从 auth0 / Application / Basic Information 下获取 | `petercat.us.auth0.com` | | `AUTH0_CLIENT_ID` | 必选 | auth0 客户端 ID,从 auth0 / Application / Basic Information 下获取 | `artfiUxxxx` | | `AUTH0_CLIENT_SECRET` | 必选 | auth0 客户端密钥, 从 auth0 / Application / Basic Information 下获取 | `xxxx-xxxx-xxx` | | `API_IDENTIFIER` | 必选 | auth0 的 API Identifier | `https://petercat.us.auth0.com/api/v2/` | | **LLM 相关的 env** | | `OPENAI_API_KEY` | 必选 | OpenAI 的密钥 | `sk-xxxx` | | `OPENAI_BASE_URL` | 可选 | API 请求的基础 URL。仅在使用代理或服务模拟器时指定。 | `https://api.openai.com/v1` | | `GEMINI_API_KEY` | 可选 | Gemini 的密钥 | `xxxx` | | `TAVILY_API_KEY` | 必选 | Tavily 的密钥 | `tvly-xxxxx` | | **注册为 Github App 的 env** | | `X_GITHUB_APP_ID` | 可选 | 注册为 Github App 时,APPID | `123456` | | `X_GITHUB_APPS_CLIENT_ID` | 可选 | 注册为 Github App 时,APP 的 Client ID | `Iv1.xxxxxxx` | | `X_GITHUB_APPS_CLIENT_SECRET` | 可选 | 注册为 Github App 时,APP 的 Client 密钥 | `xxxxxxxx` | | **限流配置** | | `RATE_LIMIT_ENABLED` | 可选 | 限流配置是否开启 | `True` | | `RATE_LIMIT_REQUESTS` | 可选 | 限流的请求数量 | `100` | | `RATE_LIMIT_DURATION` | 可选 | 限流的统计时长,单位为分钟 | `1` | | **RAG 服务配置** | | `WHISKER_API_URL` | 必选 | WHISKER RAG 服务地址 | `http://....` | | `WHISKER_API_KEY` | 必选 | WHISKER RAG 服务的 KEY | `sk-xxxx` | ## 🤝 参与贡献 > PeterCat 使用 yarn 作为包管理器 ```bash git clone https://github.com/petercat-ai/petercat.git # 安装依赖 yarn run bootstrap # 调试 client yarn run client # 调试 assistant yarn run assistant # 调试 server yarn run server # 本地启动网站 yarn run client:server # 本地启动 assistant 组件 yarn run assistant:server # assistant 构建 cd assistant yarn run build npm publish # docker 构建 yarn run build:docker # pypi 构建 yarn run build:pypi yarn run publish:pypi ``` ## 💼 企业版接入 请把您的项目地址,使用场景,使用频率等信息发送至 [[email protected] ]([email protected]) ## 📧 反馈问题 猫猫还在养成阶段,难免有些 “小脾气”,遇到问题请对它宽容一些,可以通过以下两种途径告知铲屎官: - [提交 Issue](https://github.com/petercat-ai/petercat/issues/new/choose) - [Discussions](https://github.com/petercat-ai/petercat/discussions) 提问 ## 👬 Contributors  ## 💗 Sponsor [Ant Design](https://ant.design/) ## 📄 License MIT@[PeterCat](https://github.com/petercat-ai/petercat/blob/main/LICENSE)