nonebot2/none/__init__.py

91 lines
2.5 KiB
Python
Raw Normal View History

2018-07-02 08:54:29 +00:00
import asyncio
2018-06-14 22:58:24 +00:00
import importlib
import logging
2018-07-02 08:54:29 +00:00
import os
2018-06-14 22:58:24 +00:00
import re
from typing import Any
from aiocqhttp import CQHttp
from aiocqhttp.message import Message
2018-07-04 01:28:31 +00:00
from . import default_config
2018-07-02 08:54:29 +00:00
from .log import logger
2018-06-14 22:58:24 +00:00
2018-07-04 01:28:31 +00:00
class NoneBot(CQHttp):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.config = default_config
def create_bot(config_object: Any = None) -> NoneBot:
2018-06-14 22:58:24 +00:00
if config_object is None:
2018-07-04 01:28:31 +00:00
config_object = default_config
2018-06-14 22:58:24 +00:00
kwargs = {k.lower(): v for k, v in config_object.__dict__.items()
if k.isupper() and not k.startswith('_')}
2018-07-04 01:28:31 +00:00
bot = NoneBot(message_class=Message, **kwargs)
2018-06-14 22:58:24 +00:00
bot.config = config_object
if bot.config.DEBUG:
logger.setLevel(logging.DEBUG)
else:
logger.setLevel(logging.INFO)
bot.asgi.debug = bot.config.DEBUG
2018-07-04 01:28:31 +00:00
from .message import handle_message
from .notice_request import handle_notice_or_request
2018-06-14 22:58:24 +00:00
@bot.on_message
async def _(ctx):
2018-06-27 14:05:12 +00:00
asyncio.ensure_future(handle_message(bot, ctx))
2018-06-14 22:58:24 +00:00
@bot.on_notice
async def _(ctx):
2018-06-27 14:50:01 +00:00
asyncio.ensure_future(handle_notice_or_request(bot, ctx))
2018-06-14 22:58:24 +00:00
@bot.on_request
async def _(ctx):
2018-06-27 14:50:01 +00:00
asyncio.ensure_future(handle_notice_or_request(bot, ctx))
2018-06-14 22:58:24 +00:00
return bot
_plugins = set()
2018-07-01 12:01:05 +00:00
def load_plugins(plugin_dir: str, module_prefix: str) -> None:
2018-06-26 02:25:11 +00:00
for name in os.listdir(plugin_dir):
path = os.path.join(plugin_dir, name)
2018-06-14 22:58:24 +00:00
if os.path.isfile(path) and \
2018-06-26 02:25:11 +00:00
(name.startswith('_') or not name.endswith('.py')):
2018-06-14 22:58:24 +00:00
continue
if os.path.isdir(path) and \
2018-06-26 02:25:11 +00:00
(name.startswith('_') or not os.path.exists(
2018-06-14 22:58:24 +00:00
os.path.join(path, '__init__.py'))):
continue
2018-06-26 02:25:11 +00:00
m = re.match(r'([_A-Z0-9a-z]+)(.py)?', name)
2018-06-14 22:58:24 +00:00
if not m:
continue
2018-06-26 02:25:11 +00:00
mod_name = f'{module_prefix}.{m.group(1)}'
2018-06-14 22:58:24 +00:00
try:
_plugins.add(importlib.import_module(mod_name))
logger.info('Succeeded to import "{}"'.format(mod_name))
except ImportError:
logger.warning('Failed to import "{}"'.format(mod_name))
2018-06-26 02:25:11 +00:00
2018-07-01 12:01:05 +00:00
def load_builtin_plugins() -> None:
2018-06-26 02:25:11 +00:00
plugin_dir = os.path.join(os.path.dirname(__file__), 'plugins')
load_plugins(plugin_dir, 'none.plugins')
2018-06-27 14:05:12 +00:00
2018-07-01 03:01:24 +00:00
from .command import on_command, CommandSession, CommandGroup
2018-07-01 09:51:01 +00:00
from .natural_language import on_natural_language, NLPSession, NLPResult
2018-06-27 14:50:01 +00:00
from .notice_request import (
on_notice, NoticeSession,
on_request, RequestSession,
)