Skip to content

Latest commit

 

History

History
40 lines (25 loc) · 1.91 KB

README.md

File metadata and controls

40 lines (25 loc) · 1.91 KB

bot-core

基于 Egg.js 的即将诞生的机器人后台接口服务。

背景

之前使用 Python 断断续续开发过一些 QQ 机器人的功能,后来因为一些变故导致最近想尝试通过 TypeScript 开发机器人,又由于没有一个相对成熟的框架,遂又回到 Python 去开发。仔细想想,如果不把业务逻辑耦合到具体的机器人实现中去,那不就可以复用各种各样的逻辑了吗?最好的方式应该就是通过 RESTful 接口去实现了。

后知后觉这个实现相当于 BFF(Backend For Frontend)妙啊,突然找到了理论指导 😂 各种可能用到的服务通过这一层去做统一的转换。另一个有趣的问题的是当我用 Python 去开发时,对于类型定义较为复杂的数据结构好像没有 TypeScript 来得清晰易用,所以 BFF 可以在这一层理清相关服务的接口类型定义,方便 BFF 和基于该 BFF SDK 的开发和维护。

功能说明

  • 百度搜图
  • 图灵机器人
  • bilibili 视频解析
  • SNH48
    • 票务

配套 SDK

TODO

如何使用

  • 克隆仓库
  • 安装依赖
  • 功能配置,相关 service 配置,如图灵机器人的 API key,配置完成完成后需要将文件重命名为 config.default.ts 以正确加载配置
  • 启动 npm run start
  • 关闭 npm run stop
  • 开发 npm run dev

Egg.js 踩坑

项目初始化

由于官方文档是通过 npm init egg --type=ts 来初始化 TypeScript 项目,而国内网络环境对于 npm 非常之不友好,故而导致初始化项目的时候都一度想放弃这个框架。最后在一个 issue 中找到了答案。

eslint 与 prettier 冲突

参考 Integrating with Linters 安装并使用 eslint-config-prettier 即可。