Skip to content

メッセージプラットフォームエンティティ

LangBotは複数のメッセージングプラットフォームをサポートしており、各プラットフォームには異なるメッセージエンティティフォーマットがあります。これらの違いを抽象化するために、統一された標準を実装しました。プラグイン開発者は、プラグイン内でこのページに記載されているメッセージエンティティを習得して使用するだけで、LangBotの内部メッセージ処理ロジックがメッセージの解析と変換を自動的に処理します。

メッセージチェーン

メッセージングプラットフォーム上のメッセージは、AI対話に使用されるメッセージとは異なります。メッセージングプラットフォーム上のメッセージは、メッセージチェーンの形式で記述されます。QQに表示される各独立したメッセージはメッセージチェーンであり、テキスト画像@メンションなどのさまざまなメッセージチェーンコンポーネントを含むことができます。例えば:

これは、1つのPlainコンポーネント(Hello World)と1つのImageコンポーネント(Usagi)を含むメッセージチェーンです。

メッセージチェーンとメッセージチェーンコンポーネントの定義は、langbot_plugin.api.entities.platform.messageにあります。

メッセージチェーンの構築

まず、langbot_plugin.api.entities.platform.messageパッケージをインポートして、その中のメッセージコンポーネントを使用してください。

python
from langbot_plugin.api.entities.platform.message import *

# テキスト「Hello LangBot」と画像(URLから)を含むメッセージを構築
msg_chain = MessageChain([
    Plain(text="Hello LangBot"),
    Image(url='https://qchatgpt.rockchin.top/langbot-logo.png')
])

# @全員とテキスト「Hello LangBot」を含むメッセージを構築
msg_chain = MessageChain([
    AtAll(),
    Plain(text="Hello LangBot")
])

# @特定のメンバーとテキスト「Hello LangBot」を含むメッセージを構築
msg_chain = MessageChain([
    At(target=123456),
    Plain(text="Hello LangBot")
])

現在サポートされているメッセージチェーンコンポーネント:

  • Source - ソースメッセージチェーン情報。メッセージングプラットフォームから受信したメッセージには、メッセージ情報を記録するためにメッセージチェーンの先頭にこのコンポーネントが含まれます
  • Plain - プレーンテキストメッセージ
  • Quote - 引用メッセージ
  • Image - 画像メッセージ
  • AtAll - @全員メッセージ
  • At - @特定のメンバーメッセージ
  • Voice - 音声メッセージ
    • メッセージングプラットフォームのサポートを確認する必要があります
  • Forward - 転送メッセージ
    • 多くのプラットフォームでサポートされていないため、推奨されません
  • File - ファイルメッセージ

コンポーネントを作成する際は、名前付きパラメータを使用する必要があります。具体的な使用方法については、ソースコードlangbot_plugin.api.entities.platform.messageの定義を確認してください。

その他のエンティティ

上記のエンティティに加えて、FriendGroupなどのエンティティもあります。これらのエンティティはlangbot_plugin.api.entities.platform.entitiesで定義されています。

基盤プラットフォームAPIへのアクセス

注意

4.xには適用されません。

プラットフォームの違いを抽象化するために、LangBotはメッセージングプラットフォームAPIの上に抽象化レイヤーを提供しています。これには、上記で説明した内容と、pkg/platform/sourcesディレクトリ内のさまざまなプラットフォームアダプターが含まれます。 ただし、プラットフォームの違いが大きいため、抽象化レイヤーのエンティティとAPIのカプセル化は完全ではありません。プラグインがプラットフォーム固有の機能にアクセスする必要がある場合は、次の手順に従って基盤APIにアクセスできます。

INFO

ここでのadapterは、各アダプターのインスタンス化されたオブジェクトであり、pkg/platform/sources/以下のファイル内のxxxAdapter(adapter.MessagePlatformAdapter)クラスに対応します。プラグインイベントのquery.adapterから取得できます。例えば:

python
    # 例えばプラグイン内で
    @handler(GroupMessageReceived)
    async def _(self, ctx: EventContext):
        # アダプターオブジェクトを取得
        adapter = ctx.query.adapter
プラットフォームアダプターアクセス方法説明
OneBot v11aiocqhttpadapter.botbotオブジェクトはaiocqhttp CQHttpオブジェクトに対応します。詳細な使用方法についてはaiocqhttpドキュメントを参照してください
QQ公式APIqqofficialadapter.botbotオブジェクトはlibs/qq_official_api以下のSDKオブジェクトです。詳細な使用方法については、libs/qq_official_api/api.pyのQQOfficialClient内のsend_group_text_msgメソッドを参照してHTTPリクエストメソッドを確認し、具体的なインターフェースドキュメントについてはQQ公式APIドキュメントを参照してください
WeCom(企業微信)wecomadapter.botlibs/wecom_api/api.pyのWecomClient内のsend_imageメソッドを参照してHTTPリクエストメソッドを確認し、具体的なインターフェースドキュメントについてはWeCom APIドキュメントを参照してください
WeChat公式アカウントofficialaccount-インターフェースドキュメントについてはWeChat公式アカウントAPIドキュメントを参照してください。認証情報はadapter.botから取得できます
Larklarkadapter.api_clientLark SDKのAPI Clientオブジェクトです。詳細についてはoapi-sdk-pythonを参照してください
DingTalkdingtalk-DingTalk APIドキュメントを参照してください。認証情報はadapter.botから取得できます
Discorddiscordadapter.botbotオブジェクトはRapptz/discord.py Discordオブジェクトです。詳細な使用方法についてはドキュメントを参照してください
Telegramtelegramadapter.botbotオブジェクトはpython-telegram-bot Telegramオブジェクトです。詳細な使用方法についてはドキュメントを参照してください
Slackslackadapter.botbotオブジェクトはlibs/slack_api/api.py内にあります。詳細な使用方法についてはそのコードとSlack SDKを参照してください