2020-06-30 10:13:58 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import logging
|
2020-07-04 22:51:10 +08:00
|
|
|
import importlib
|
|
|
|
from typing import Optional
|
|
|
|
from ipaddress import IPv4Address
|
|
|
|
|
2020-07-05 20:39:34 +08:00
|
|
|
from nonebot.log import logger
|
|
|
|
from nonebot.config import Env, Config
|
|
|
|
from nonebot.drivers import BaseDriver
|
2020-07-04 22:51:10 +08:00
|
|
|
|
|
|
|
_driver: Optional[BaseDriver] = None
|
|
|
|
|
|
|
|
|
|
|
|
def get_driver() -> BaseDriver:
|
|
|
|
if _driver is None:
|
|
|
|
raise ValueError("NoneBot has not been initialized.")
|
|
|
|
return _driver
|
|
|
|
|
|
|
|
|
|
|
|
def get_app():
|
|
|
|
driver = get_driver()
|
|
|
|
return driver.server_app
|
|
|
|
|
|
|
|
|
|
|
|
def get_asgi():
|
|
|
|
driver = get_driver()
|
|
|
|
return driver.asgi
|
|
|
|
|
|
|
|
|
2020-08-07 11:18:02 +08:00
|
|
|
def init(*, _env_file: Optional[str] = None, **kwargs):
|
2020-07-04 22:51:10 +08:00
|
|
|
global _driver
|
|
|
|
env = Env()
|
|
|
|
config = Config(**kwargs, _env_file=_env_file or f".env.{env.environment}")
|
|
|
|
|
|
|
|
logger.setLevel(logging.DEBUG if config.debug else logging.INFO)
|
|
|
|
logger.debug(f"Loaded config: {config.dict()}")
|
|
|
|
|
|
|
|
Driver = getattr(importlib.import_module(config.driver), "Driver")
|
|
|
|
_driver = Driver(config)
|
|
|
|
|
|
|
|
|
|
|
|
def run(host: Optional[IPv4Address] = None,
|
|
|
|
port: Optional[int] = None,
|
|
|
|
*args,
|
|
|
|
**kwargs):
|
|
|
|
get_driver().run(host, port, *args, **kwargs)
|
2020-06-30 10:13:58 +08:00
|
|
|
|
|
|
|
|
2020-07-05 20:39:34 +08:00
|
|
|
from nonebot.plugin import load_plugins, get_loaded_plugins
|