File size: 2,393 Bytes
0b1aeae
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
from .Extension import Extension
import requests

# 拓展的配置信息,用于ai理解拓展的功能 *必填*
ext_config:dict = {
    "name": "LoliconPic",   # 拓展名称,用于标识拓展
    "arguments": {      
        "tag": "str",   # 关键字
    },
    "description": "send 1 specified tag anime picture. (usage in response: /#LoliconPic&萝莉#/)",
    # 参考词,用于上下文参考使用,为空则每次都会被参考(消耗token)
    "refer_word": ["图", "pic", "Pic", "再", "还", "涩", "色"],
    # 每次消息回复中最大调用次数,不填则默认为99
    "max_call_times_per_msg": 3,
    # 作者信息
    "author": "CCYellowStar",
    # 版本
    "version": "0.0.1",
    # 拓展简介
    "intro": "发送指定tag二次元图片",
}

class CustomExtension(Extension):
    async def call(self, arg_dict: dict, ctx_data: dict) -> dict:
        """ 当拓展被调用时执行的函数 *由拓展自行实现*
        
        参数:
            arg_dict: dict, 由ai解析的参数字典 {参数名: 参数值(类型为str)}
        """
        custom_config:dict = self.get_custom_config()  # 获取yaml中的配置信息
        r18 = 0 #添加r18参数 0为否,1为是,2为混合
        tag = arg_dict.get('tag', None)

        url = f"https://api.lolicon.app/setu/v2?tag={tag}&r18={r18}"
        res = requests.get(url, verify=False, timeout=10)
        data=res.json()
        if not data["error"]:
            if data["data"]:
                data = data["data"][0]
                img_src = data["urls"]["original"]
            else:
                return {
                    'text': f"[来自拓展] 没有这个tag的图片...",
                    'image': None,  # 图片url
                    'voice': None,  # 语音url
                }
        if img_src is None:
            return {
                'text': f"[来自拓展] 发送图片错误或超时...",
                'image': None,  # 图片url
                'voice': None,  # 语音url
            }
        else:
            # 返回的信息将会被发送到会话中
            return {
                'text': None,       # 文本信息
                'image': img_src,   # 图片url
                'voice': None,      # 语音url
            }

    def __init__(self, custom_config: dict):
        super().__init__(ext_config.copy(), custom_config)