Metadata-Version: 2.1
Name: cesloi
Version: 0.6.11
Summary: An simple Python SDK base on mirai-api-http v2
Home-page: https://github.com/RF-Tar-Railt/Cesloi
Author: ArcletProject
Author-email: rf_tar_railt@qq.com
License: AGPL 3.0
Keywords: mirai,bot,asyncio,http,websocket
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Operating System :: OS Independent
Requires-Python: >=3.8
Description-Content-Type: text/rst
License-File: LICENSE

Cesloi for mirai-api-http
=========================

|Licence| |PyPI| |PyPI - Python Version|

一个简易(?)，基于
```mirai-api-http v2`` <https://github.com/project-mirai/mirai-api-http>`__
的 Python SDK。

**本项目适用于 mirai-api-http 2.0 以上版本**\ 。

项目仍处于开发阶段，部分内容可能会有较大改变

注: mirai-api-http 需要启用ws adapter和http adapter

文档
----

`Cesloi暂时的文档 <https://github.com/RF-Tar-Railt/Cesloi/wiki>`__

安装
----

``pip install arclet-cesloi``

简单的开始
----------

通常版本
~~~~~~~~

.. code:: python

    from arclet.cesloi.bot_client import Cesloi
    from arclet.cesloi.model.relation import Friend
    from arclet.cesloi.communicate_with_mah import BotSession
    from arclet.cesloi.message.alconna import Alconna, Arpamar, AlconnaParser

    bot = Cesloi(bot_session=BotSession(host="http://localhost:8080", account=1234567890, verify_key="INITKEYWylsVdbr"),
                 debug=False)

    @bot.register(
        "FriendMessage",
        decorators=[AlconnaParser(alconna=Alconna(command="Hello"))]
    )
    async def test(app: Cesloi, friend: Friend, result: Arpamar):
        await app.send_with(friend, "Hello, World!")
        if result.matched:
            await app.send_with(friend,nudge=True)
        
    bot.start()

使用插件的版本
~~~~~~~~~~~~~~

In ``main.py`` :

.. code:: python

    from arclet.cesloi.bot_client import Cesloi
    from arclet.cesloi.communicate_with_mah import BotSession


    bot = Cesloi(bot_session=BotSession(host="http://localhost:8080", account=1234567890, verify_key="INITKEYWylsVdbr"), debug=False)
    bot.install_plugins("test_plugins")
    bot.start()

In ``test_plugins/example_plugin.py`` :

.. code:: python

    from arclet.cesloi.bot_client import Cesloi
    from arclet.cesloi.model.relation import Friend
    from arclet.cesloi.message.alconna import Alconna, Arpamar, AlconnaParser
    from arclet.cesloi.plugin import Bellidin as bd


    @bd.model_register(
        "FriendMessage",
        decorators=[AlconnaParser(alconna=Alconna(command="Hello"))]
    )
    async def test(app: Cesloi, friend: Friend, result: Arpamar):
        await app.send_with(friend, "Hello, World!")
        if result.matched:
            await app.send_with(friend,nudge=True)

未来开发计划
------------

**一期计划** - [STRIKEOUT:CommandAnalysis，
一个抽象的命令/命令参数处理器] (已实现) - [STRIKEOUT:TimeScheduler，
一个根据时间选择是否执行目标函数的容器]\ (已实现) -
[STRIKEOUT:PluginManager， 不局限于在一个文件中运行方法] (已实现)

**二期计划** - Interrupt, 中断处理 -
[STRIKEOUT:Decorator，用户自定义的处理器] (已实现)

鸣谢&相关项目
-------------

    这些项目也很棒, 去他们的项目页看看, 点个 ``Star``
    以鼓励他们的开发工作, 毕竟没有他们也没有 ``Cesloi``.

    特别感谢 ```mamoe`` <https://github.com/mamoe>`__
    给我们带来这些精彩的项目: -
    ```mirai`` <https://github.com/mamoe/mirai>`__: 一个高性能,
    高可扩展性的 QQ 协议库 -
    ```mirai-console`` <https://github.com/mamoe/mirai-console>`__:
    一个基于 ``mirai`` 开发的插件式可扩展开发平台 -
    ```mirai-api-http`` <https://github.com/project-mirai/mirai-api-http>`__:
    为本项目提供与 ``mirai`` 交互方式的 ``mirai-console`` 插件

```GraiaProject`` <https://github.com/GraiaProject>`__ 下的项目: -
```Broadcast Control`` <https://github.com/GraiaProject/BroadcastControl>`__:
本项目关于参数解析与事件循环的的\ [STRIKEOUT:解剖]\ 学习对象。 -
```Application`` <https://github.com/GraiaProject/Application/>`__:
本项目的通用功能的\ [STRIKEOUT:解剖]\ 学习与参考对象。 -
```Ariadne`` <https://github.com/GraiaProject/Ariadne/>`__:
本项目关于网络部分的学习与参考对象。

许可证
~~~~~~

```GNU AGPLv3`` <https://choosealicense.com/licenses/agpl-3.0/>`__
是本项目的开源许可证.

.. |Licence| image:: https://img.shields.io/github/license/RF-Tar-Railt/Cesloi
   :target: https://github.com/RF-Tar-Railt/Cesloi/blob/master/LICENSE
.. |PyPI| image:: https://img.shields.io/pypi/v/cesloi
   :target: https://pypi.org/project/cesloi
.. |PyPI - Python Version| image:: https://img.shields.io/pypi/pyversions/cesloi
   :target: https://www.python.org/


