This repository has been archived by the owner on Aug 20, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy path__init__.py
412 lines (380 loc) · 13.5 KB
/
__init__.py
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
import json
import os
import traceback
from nonebot import scheduler
import hoshino
HELP_MSG = '''
来 [num] 张 [keyword] 涩/色/瑟图 : 来num张keyword的涩图(不指定数量与关键字发送一张随机涩图)
涩/色/瑟图 : 发送一张随机涩图
提取图片pid : 获取指定id的p站图片,没有时发送链接
本日涩图排行榜 [page] : 获取[第page页]p站排行榜(需开启acggov模块)
看涩图 [n] 或 [start end] : 获取p站排行榜[第n名/从start名到end名]色图(需开启acggov模块)
'''
sv = hoshino.Service('涩图', bundle='pcr娱乐', help_=HELP_MSG)
config_default = {
"base": {
"daily_max": 20, # 每日上限次数
"freq_limit": 300, # 频率限制
"whitelistmode": False, # 白名单模式开关
"blacklistmode": False, # 黑名单模式开关
"ban_if_group_num_over": 3000, # 字面意思
"max_pic_once_send": 1, # 一次最大发送图片数量
"enable_forward_msg": True # 启用转发消息模式
},
"default": {
"withdraw": 45, # 撤回时间,单位秒
"lolicon": True, # lolicon模块开关
"lolicon_r18": False, # lolicon_r18模块开关
"acggov": False # acggov模块开关
},
"lolicon": {
"mode": 2, # 0禁用 1无缓存 2有缓存在线 3有缓存离线
"r18": False, # R18图开关
"use_thumb": True, # 选取小图开关
"pixiv_direct": False, # 是否直连pixiv
"proxy_site": "https://i.pixiv.re", # pixiv代理地址
"local_proxy": "" # lolicon代理地址
},
"acggov": {
"mode": 2, # 0禁用 1无缓存 2有缓存在线 3有缓存离线
"apikey": "", # acggov API
"ranking_mode": "daily", # 排行榜模式
"per_page": 25, # 一米哇甘耐
"use_thumb": True, # 选取小图开关
"pixiv_direct": False, # 是否直连pixiv
"pixiv_proxy": "https://i.pixiv.re", # pixiv代理地址
"acggov_proxy": "" # acggov代理地址
}
}
group_list_default = {
"white_list": [
],
"black_list": [
]
}
groupconfig_default = {}
# Check config if exist
pathcfg = os.path.join(os.path.dirname(__file__), 'config.json')
if not os.path.exists(pathcfg):
try:
with open(pathcfg, 'w') as cfgf:
json.dump(config_default, cfgf, ensure_ascii=False, indent=2)
hoshino.logger.error('[WARNING]未找到配置文件,已根据默认配置模板创建,请打开插件目录内config.json查看和修改。')
except:
hoshino.logger.error('[ERROR]创建配置文件失败,请检查插件目录的读写权限及是否存在config.json。')
traceback.print_exc()
# check group list if exist
glpath = os.path.join(os.path.dirname(__file__), 'grouplist.json')
if not os.path.exists(glpath):
try:
with open(glpath, 'w') as cfggl:
json.dump(group_list_default, cfggl, ensure_ascii=False, indent=2)
hoshino.logger.error('[WARNING]未找到黑白名单文件,已根据默认黑白名单模板创建。')
except:
hoshino.logger.error('[ERROR]创建黑白名单文件失败,请检查插件目录的读写权限。')
traceback.print_exc()
# check group config if exist
gpcfgpath = os.path.join(os.path.dirname(__file__), 'groupconfig.json')
if not os.path.exists(gpcfgpath):
try:
with open(gpcfgpath, 'w') as gpcfg:
json.dump(groupconfig_default, gpcfg, ensure_ascii=False, indent=2)
hoshino.logger.error('[WARNING]未找到群个体设置文件,已创建。')
except:
hoshino.logger.error('[ERROR]创建群个体设置文件失败,请检查插件目录的读写权限。')
traceback.print_exc()
from .base import *
from .config import get_config, get_group_config, get_group_info, set_group_config, group_list_check, set_group_list
# 设置limiter
tlmt = hoshino.util.DailyNumberLimiter(get_config('base', 'daily_max'))
flmt = hoshino.util.FreqLimiter(get_config('base', 'freq_limit'))
def check_lmt(uid, num, gid):
if uid in hoshino.config.SUPERUSERS:
return 0, ''
if group_list_check(gid) != 0:
if group_list_check(gid) == 1:
return 1, f'此功能启用了白名单模式,本群未在白名单中,请联系维护组解决'
else:
return 1, f'此功能已在本群禁用,可能因为人数超限或之前有滥用行为,请联系维护组解决'
if not tlmt.check(uid):
return 1, f"您今天已经冲过{get_config('base', 'daily_max')}次了,请明天再来~"
if num > 1 and (get_config('base', 'daily_max') - tlmt.get_num(uid)) < num:
return 1, f"您今天的剩余次数为{get_config('base', 'daily_max') - tlmt.get_num(uid)}次,已不足{num}次,请少冲点(恼)!"
if not flmt.check(uid):
return 1, f'您冲的太快了,{round(flmt.left_time(uid))}秒后再来吧~'
# tlmt.increase(uid,num)
flmt.start_cd(uid)
return 0, ''
def render_forward_msg(msg_list: list, uid=2854196306, name='小冰'):
forward_msg = []
for msg in msg_list:
forward_msg.append({
"type": "node",
"data": {
"name": str(name),
"uin": str(uid),
"content": msg
}
})
return forward_msg
async def send_msg(msg_list, ev):
result_list = []
if not get_config('base', 'enable_forward_msg'):
for msg in msg_list:
try:
result_list.append(await hoshino.get_bot().send(ev, msg))
except:
hoshino.logger.error('[ERROR]图片发送失败')
await hoshino.get_bot().send(ev, f'涩图太涩,发不出去力...')
await asyncio.sleep(1)
else:
forward_msg = render_forward_msg(msg_list)
try:
result_list.append(await hoshino.get_bot().send_group_forward_msg(group_id=ev.group_id, messages=forward_msg))
except:
traceback.print_exc()
hoshino.logger.error('[ERROR]图片发送失败')
await hoshino.get_bot().send(ev, f'涩图太涩,发不出去力...')
await asyncio.sleep(1)
return result_list
@sv.on_prefix('setu')
async def send_setu(bot, ev):
uid = ev['user_id']
gid = ev['group_id']
is_su = hoshino.priv.check_priv(ev, hoshino.priv.SUPERUSER)
args = ev.message.extract_plain_text().split()
msg = ''
if not is_su:
msg = '需要超级用户权限\n发送"帮助 pcr娱乐"获取操作指令'
elif len(args) == 0:
msg = '无效参数\n发送"帮助 pcr娱乐"获取操作指令'
elif args[0] == '设置' and len(args) >= 3: # setu set module on [group]
if len(args) >= 4 and args[3].isdigit():
gid = int(args[3])
if args[1] == 'lolicon':
key = 'lolicon'
elif args[1] == 'lolicon_r18':
key = 'lolicon_r18'
elif args[1] == 'acggov':
key = 'acggov'
elif args[1] == '撤回':
key = 'withdraw'
else:
key = None
if args[2] == '开' or args[2] == '启用':
value = True
elif args[2] == '关' or args[2] == '禁用':
value = False
elif args[2].isdigit():
value = int(args[2])
else:
value = None
if key and (not value is None):
set_group_config(gid, key, value)
msg = '设置成功!当前设置值如下:\n'
msg += f'群/{gid} : 设置项/{key} = 值/{value}'
else:
msg = '无效参数'
elif args[0] == '状态':
if len(args) >= 2 and args[1].isdigit():
gid = int(args[1])
withdraw_status = "不撤回" if get_group_config(gid, "withdraw") == 0 else f'{get_group_config(gid, "withdraw")}秒'
lolicon_status = "启用" if get_group_config(gid, "lolicon") else "禁用"
lolicon_r18_status = "启用" if get_group_config(gid, "lolicon_r18") else "禁用"
acggov_status = "启用" if get_group_config(gid, "acggov") else "禁用"
msg = f'群 {gid} :'
msg += f'\n撤回时间: {withdraw_status}'
msg += f'\nlolicon 源: {lolicon_status}'
msg += f'\nlolicon_r18 源: {lolicon_r18_status}'
msg += f'\nacggov 源: {acggov_status}'
elif args[0] == '缓存':
await bot.send(ev, '开始缓存')
await fetch_process()
msg = '缓存进程结束'
elif args[0] == '仓库':
msg = '仓库:'
state = check_path()
for k, v in state.items():
msg += f'\n{k}源 : {v}张'
elif args[0] == "黑名单" and len(args) == 3: # setu 黑名单 新增/删除 gid(一次只能提供一个)
if args[1] in ["新增", "添加"]:
mode = 0
elif args[1] in ["删除", "移除"]:
mode = 1
else:
await bot.finish(ev,"操作错误,应为新增/删除其一")
group_id = args[2]
statuscode, failedgid = set_group_list(group_id, 1, mode)
if statuscode == 403:
msg = '无法访问黑白名单'
elif statuscode == 404:
msg = f'群{failedgid[0]}不在黑名单中'
elif statuscode == 401:
msg = f'警告!黑名单模式未开启!\n成功{args[1]}群{group_id}'
else:
msg = f'成功{args[1]}群{group_id}'
elif args[0] == '白名单' and len(args) == 3: # setu 白名单 新增/删除 gid(一次只能提供一个)
if args[1] in ["新增", "添加"]:
mode = 0
elif args[1] in ["删除", "移除"]:
mode = 1
else:
await bot.finish(ev, "操作错误,应为新增/删除其一")
group_id = args[2]
statuscode, failedgid = set_group_list(group_id, 0, mode)
if statuscode == 403:
msg = '无法访问黑白名单'
elif statuscode == 404:
msg = f'群{failedgid[0]}不在白名单中'
elif statuscode == 402:
msg = f'警告!白名单模式未开启!\n成功{args[1]}群{group_id}'
else:
msg = f'成功{args[1]}群{group_id}'
else:
msg = '无效参数'
await bot.send(ev, msg)
@sv.on_rex(r'^[色涩瑟][图圖]$|^[来來发發给給]((?P<num>\d+)|(?:.*))[张張个個幅点點份丶](?P<keyword>.*?)[色涩瑟][图圖]$')
async def send_search_setu(bot, ev):
uid = ev['user_id']
gid = ev['group_id']
num = ev['match'].group('num')
if num:
try:
num = int(num)
max_num = int(get_config('base', 'max_pic_once_send'))
if num > max_num:
await bot.send(ev, f'太贪心辣,一次只能要{max_num}份涩图哦~')
num = max_num
else:
pass
except:
num = 1
else:
num = 1
result, msg = check_lmt(uid, num, gid)
if result != 0:
await bot.send(ev, msg)
return
keyword = ev['match'].group('keyword')
result_list = []
msg_list = []
if not keyword:
for _ in range(num):
msg = await get_setu(gid)
if msg == None:
await bot.send(ev, '获取图片失败了,可能有以下原因:\n没有启用任何一个setu模块\n网络不佳/配置有误\n初次使用,请使用"setu 缓存"来缓存图片后再发送')
return
msg_list.append(msg)
result_list = await send_msg(msg_list, ev)
else:
keyword = keyword.strip()
await bot.send(ev, '搜索中...')
msg_list = await search_setu(gid, keyword, num)
if len(msg_list) == 0:
await bot.send(ev, '没~找~到~哦,随机赠送你一份setu吧~\n可能原因:1.没有使用标准或正式角色名称\n2.兄啊,你的XP怎么这么怪啊.jpg\n3.网络不佳/搜索额度超限')
for _ in range(num):
msg = await get_setu(gid)
if msg == None:
await bot.send(ev, '获取图片失败了,可能有以下原因:\n没有启用任何一个setu模块\n网络不佳/配置有误\n初次使用,请使用"setu 缓存"来缓存图片后再发送')
return
msg_list.append(msg)
result_list = await send_msg(msg_list, ev)
else:
result_list = await send_msg(msg_list, ev)
tlmt.increase(uid, len(result_list))
second = get_group_config(gid, "withdraw")
if second and second > 0:
await asyncio.sleep(second)
for result in result_list:
try:
await bot.delete_msg(self_id=ev['self_id'], message_id=result['message_id'])
except:
traceback.print_exc()
hoshino.logger.error('[ERROR]撤回失败')
await asyncio.sleep(1)
@sv.on_rex(r'^[本每]日[涩色瑟]图排行榜\D*(\d*)')
async def send_ranking(bot, ev):
gid = ev['group_id']
page = ev['match'].group(1)
if page and page.isdigit():
page = int(page)
page -= 1
else:
page = 0
if page < 0:
page = 0
msg = await get_ranking(gid, page)
if msg == None:
msg = '模块未启用'
await send_msg(msg, ev)
@sv.on_prefix(('看涩图', '看色图', '看瑟图'))
async def send_ranking_setu(bot, ev):
uid = ev['user_id']
gid = ev['group_id']
start = 0
end = 0
args = ev.message.extract_plain_text().split()
if len(args) > 0 and args[0].isdigit():
start = int(args[0])
start -= 1
if start < 0:
start = 0
end = start + 1
if len(args) > 1 and args[1].isdigit():
end = int(args[1])
result, msg = check_lmt(uid, end - start, gid)
if result != 0:
await bot.send(ev, msg)
return
msg_list = []
for i in range(start, end):
msg = await get_ranking_setu(gid, i)
if msg == None:
await bot.send(ev, '模块未启用')
return
msg_list.append(msg)
result_list = await send_msg(msg_list, ev)
tlmt.increase(uid, len(result_list))
second = get_group_config(gid, "withdraw")
if second and second > 0:
if not get_config('base', 'enable_forward_msg'):
await asyncio.sleep(second)
for result in result_list:
try:
await bot.delete_msg(self_id=ev['self_id'], message_id=result['message_id'])
except:
traceback.print_exc()
hoshino.logger.error('[ERROR]撤回失败')
await asyncio.sleep(1)
@sv.on_prefix('提取图片')
async def get_spec_setu(bot, ev):
args = ev.message.extract_plain_text().split()
try:
args = args[0]
except:
await bot.send(ev, '请在命令之后提供p站id哦~')
return
args = str(args)
if len(args) == 8:
msg = get_spec_image(args)
if not msg:
await bot.send(ev, f'没有在本地找到这张图片/不支持r18图片的提取\n原图地址:https://pixiv.lancercmd.cc/{args}')
else:
await bot.send(ev, msg)
else:
await bot.send(ev, 'p站id无效,应为8位数字id哦~')
@sv.scheduled_job('interval', minutes=10)
async def fetch_setu_process():
await fetch_process()
# @sv.on_fullmatch('test')
@scheduler.scheduled_job('cron', hour=4, minute=40)
async def set_ban_list():
ban_list = []
group_info = await get_group_info(info_type='member_count')
for group in group_info:
group_info[group] = int(group_info[group])
if group_info[group] >= int(get_config('base', 'ban_if_group_num_over')):
ban_list.append(group)
else:
pass
set_group_list(ban_list, 1, 0)