/KiviBot-Primitive

Just run の Bot. 基于 `oicq` / `icqq`,面向 `Node.js` 开发者的轻量 QQ 机器人框架

Primary LanguageTypeScriptMozilla Public License 2.0MPL-2.0

Kivi logo


npm package node compatibility NPM


Kivi

Just run の bot.

基于 oicq / icqq、面向 Node.js 开发者的轻量 QQ 机器人框架。

more info

The mascot is Dimo, a star-level pet of the light element introduced in the game "Roco Kingdom" in 2012. It represents dreams and courage, and the image copyright belongs to Roco Kingdom.

为什么选择 Kivi ?

  • 🚲 轻量:无 UI、低占用、安装后大小不到 10MB
  • ⚡ 高效:内置协议、语言一致,由 node / bun 强力驱动
  • 📱 跨平台:Windows、Linux、手机平板、路由器、随身 WiFi...
  • 🔗 多协议:得益于 oicq / icqq,支持手机、平板、手表、macOS
  • 📦 注重体验: 一条 QQ 消息即可启用、禁用插件,管理 Bot
  • 🚤 极速开发: 极低门槛,几行 JS/TS 代码即能快速实现功能
  • 💻 开发者友好: 支持直接加载 TS 插件、插件热重载、完备的 TS 类型

本项目开发初衷在于提高群活跃氛围、方便群管理,仅供个人娱乐、学习和交流使用,任何人不得将本项目用于任何非法用途

快速上手

项目依赖 Node.js,请确保本地已安装,且版本 >= 16.14。

  1. 通过 npm create kivi 命令快速创建项目
npm create kivi
  1. 进入项目目录,并安装依赖
cd kivi-bot
npm install
  1. 通过 npm 命令启动 Kivi
npm start

向机器人发送 .h 或者 .help 开始你的 Bot 养成计划~

插件

框架本身仅提供插件管理状态监控的基础功能, 其他应用性功能你需要通过编写插件来实现。

插件全部放在 plugins 目录,每个插件都是一个单独的 ESM 模块,支持 TS/JS。

插件数据被存放在 data/plugins/[pluginName] 下,pluginNamesetup 函数设置的名称。

你可以在 plugins/demo/index.ts 创建一个文件,写入以下 TS 代码

请注意最后需要导出 plugin

import { setup, logger, useInfo, useMount } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

useMount(async (bot) => {
  logger.info('日志:插件被启用了!')

  const { mainAdmin } = useInfo()

  bot.sendPrivateMsg(mainAdmin, '私聊消息:插件被启用了!')

  return () => {
    logger.info('插件被禁用了!')
  }
})

export { plugin } from '@kivi-dev/plugin'

然后发送 .p on demo 给 Bot 即可启用插件。

插件例子

  1. 收到 hello 或者群聊的 hi 时,回复 world + 爱心。
import { setup, defineMsgHandler, useMount, segment, useMessage, useMatch } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

const handler = defineMsgHandler((event) => {
  if (event.raw_message === 'hi') {
    event.reply(['world ', segment.face(66)])
  }
})

useMount(() => {
  useMatch('hello', (event) => {
    event.reply(['world ', segment.face(66)])
  })

  // 仅群聊
  useMessage(handler, { type: 'group' })
})

export { plugin } from '@kivi-dev/plugin'
  1. 定时任务
import { setup, bot, useMount, useCron, useInfo } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

useMount(() => {
  const { mainAdmin } = useInfo()

  // 使用 crontab 表达式
  useCron('*/3 * * * *', (event, now, cron) => {
    // 每 3 秒给主管理员发送一条消息
    bot().sendPrivateMsg(mainAdmin, '定时任务触发了!')
  })
})

export { plugin } from '@kivi-dev/plugin'
  1. 处理命令
import { setup, defineCmdHandler, defineCmdMap, useMount, useCmd, logger } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

const handler = defineCmdHandler((event, params, options) => {
  // 比如 /admin p1 p2 -abc -key value --option1=test -option2=hello
  logger.info(params, options)
  event.reply('world')
})

const handlersMap = defineCmdMap({
  // 处理 /hello test 命令
  test(event, params, options) {
    // 比如 /hello test -abc -key value --option1=test -option2=hello
    logger.log(params, options)
    event.reply('world')
  },
})

useMount(() => {
  // 仅处理 群聊 中 管理员 的命令
  useCmd('/admin', handler, { role: 'admin', type: 'group' })

  // 支持 直接声明 子命令处理函数
  useCmd('/hello', handlersMap)
})

export { plugin } from '@kivi-dev/plugin'
  1. 持久化数据
import { setup, useMount, logger, useConfig } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

useMount(() => {
  const config = useConfig({ value: 0 }) // 可选设置默认 config 和配置其它参数
  // const config = useConfig({ value: 0 }, { filename: 'data.json', minify: false })

  logger.info(config) // 第二次启用将会 输出 { value: 114514 }

  config.value = 114514 // 检测到 config 变更将自动保存,下次启用自动读取
})

export { plugin } from '@kivi-dev/plugin'
  1. 插件间通信 (注册 API)

提供了一种多个插件间通信的机制,通过 registerApi 注册 API,通过 useApi 使用 API。

import { setup, useMount, registerApi, useApi } from '@kivi-dev/plugin'

setup('测试插件', '1.0.0')

// 插件 A
useMount(() => {
  registerApi('testFunc', (a, b) => a + b)
})

// 插件 B
useMount(() => {
  // 得到 3
  const res = useApi('testFunc')(1, 2)
})

export { plugin } from '@kivi-dev/plugin'

API

完善中...

Docker 部署

确保安装了 Docker 环境,拷贝仓库源码里的 Dockerfile.dockerignoredocker-compose.yml 到你的项目根目录下,然后在项目根目录执行以下命令即可。

docker build -t kivi .
docker compose up -d

更多

遇到困难?请尝试翻阅 插件 API 源码 或者加入企鹅群 868781587 礼貌提问。

qrcode

License

MPL-2.0