Skip to main content

Universal Information Model for Nonebot2

Project description

nonebot

nonebot-plugin-uninfo

Nonebot2 多平台的会话信息(用户、群组、频道)获取插件 ✨

license Python NoneBot pypi

本插件提供了多个模型,可以从不同适配器的 BotEvent 中提取与会话相关的属性

安装

  • 使用 nb-cli
nb plugin install nonebot-plugin-uninfo
  • 使用 pip
pip install nonebot-plugin-uninfo

使用

获取 Session

from nonebot_plugin_uninfo import get_session

@matcher.handle()
async def handle(bot: Bot, event: Event):
    session = await get_session(bot, event)

或使用依赖注入的形式:

from nonebot_plugin_uninfo import Uninfo, UniSession, Session

@matcher.handle()
async def handle(session: Session = UniSession()):
    ...

@matcher.handle()
async def handle1(session: Uninfo):
    ...

拉取用户/群组/频道列表:

from nonebot_plugin_uninfo import SceneType, QryItrface

@matcher.handle()
async def handle(interface: QryItrface):
    users = await interface.get_users()
    groups = await interface.get_scenes(SceneType.GROUP)
    members = await interface.get_members(groups[0].type, groups[0].id)

使用内建的 Permission:

from nonebot import on_command
from nonebot_plugin_uninfo import ADMIN

matcher = on_command("inspect", permission=ADMIN())

模型定义

User

属性 类型 含义 备注
id str 用户 id
name str | None 用户名称
nick str | None 用户昵称 好友备注
avatar str | None 用户头像
gender str 用户性别

Scene

属性 类型 含义 备注
id str 场景 id
type SceneType 场景类型 可分为 Private, Group, GuildChannel_XXX
name str | None 场景名称
avatar str | None 场景图标
parent Scene | None 父级场景 适用于频道的二级群组场景, 或针对临时会话的来源群组

Member

属性 类型 含义 备注
user User 成员的用户信息
nick str | None 成员昵称
role str | None 成员角色组 当可能存在多个角色组时,此处会使用 level 最高的那个
mute MuteInfo | None 成员禁言信息
joined_at datetime | None 成员加入时间

Session

属性 类型 含义 备注
self_id str 机器人 id
adapter str 适配器名称
scope str 适配器范围 相比 adapter 更指向实际平台
scene Scene 事件场景
user User 用户信息
member Member | None 成员信息 仅适用于群组,频道场景
operator Member | None 操作者信息 仅适用于群组,频道场景

示例

from nonebot_plugin_uninfo import Uninfo
from nonebot import on_command

matcher = on_command("inspect", aliases={"查看"}, priority=1)


@matcher.handle()
async def inspect(session: Uninfo):
    texts = [
        f"平台名: {session.adapter} | {session.scope}",
        f"用户ID: {session.user.name + ' | ' if session.user.name else ''}{session.user.id}",
        f"自身ID: {session.self_id}",
        f"事件场景: {session.scene.type.name}",
        f"频道 ID: {session.scene.name + ' | ' if session.scene.name else ''}{session.scene.id}"
    ]
    if session.scene.parent:
        texts.append(f"群组 ID: {session.scene.parent.name + ' | ' if session.scene.parent.name else ''}{session.scene.parent.id}")
    if session.member:
        texts.append(f"成员 ID: {session.member.nick + ' | ' if session.member.nick else ''}{session.member.id}")
    await matcher.send("\n".join(texts))

支持的 adapter

  • OneBot v11
  • OneBot v12
  • Console
  • Kook (Kaiheila)
  • Github
  • Telegram
  • Feishu
  • Discord
  • QQ
  • Satori
  • DoDo
  • Kritor
  • Mirai
  • Tailchat
  • Mail
  • WXMP
  • heybox
  • Gewechat
  • Milky

相关插件

  • nonebot-plugin-alconna 强大的 Nonebot2 命令匹配拓展,支持富文本/多媒体解析,跨平台消息收发

鸣谢

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nonebot_plugin_uninfo-0.8.1.tar.gz (40.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nonebot_plugin_uninfo-0.8.1-py3-none-any.whl (64.6 kB view details)

Uploaded Python 3

File details

Details for the file nonebot_plugin_uninfo-0.8.1.tar.gz.

File metadata

  • Download URL: nonebot_plugin_uninfo-0.8.1.tar.gz
  • Upload date:
  • Size: 40.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: pdm/2.25.0 CPython/3.12.3 Linux/6.11.0-1015-azure

File hashes

Hashes for nonebot_plugin_uninfo-0.8.1.tar.gz
Algorithm Hash digest
SHA256 b5f82b281cb60df33eb335201ada74b5f7c855445b28919c5cb9ab4c93fff94d
MD5 0ae834066580d612248eeb7739f37b61
BLAKE2b-256 ffa4e04a3559a5900093f1f7ee5662fb9911f1fac0c490cd3e9c1413f9ca0c0c

See more details on using hashes here.

File details

Details for the file nonebot_plugin_uninfo-0.8.1-py3-none-any.whl.

File metadata

File hashes

Hashes for nonebot_plugin_uninfo-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 618c34a2a4c38682cb094f3dbc3be2d1550c037e5b75a6a30b6189d67d6d9e68
MD5 dc7997c2ac484ada3966d786fe862c34
BLAKE2b-256 e01ef95f6992ea5d5b4d5f4993734c74284605133c10c4203a1c7e63e7cd3a3d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page