summaryrefslogtreecommitdiff
path: root/ATRI/__init__.py
blob: c795e29080f999f8fa0e136c7e6175221432b92e (plain)
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
#!/usr/bin/env python3
# -*- encoding: utf-8 -*-
'''
@File    :   __init__.py
@Time    :   2020/11/21 09:53:07
@Author  :   Kyomotoi
@Contact :   [email protected]
@Github  :   https://github.com/Kyomotoi
@License :   Copyright © 2018-2020 Kyomotoi, All Rights Reserved.
'''
__author__ = 'kyomotoi'

from .check import checkATRI

checkATRI().chechConfig()
checkATRI().checkRely()

import time
import nonebot
import datetime
from pathlib import Path
from .utils.utils_yml import load_yaml
from nonebot.log import default_format, logger

COPYRIGHT = (r"""====================[ATRI | アトリ]====================
* Mirai + NoneBot2 + Python
* Copyright © 2018-2020 Kyomotoi,All Rights Reserved
* Project: https://github.com/Kyomotoi/ATRI
* Blog: blog.lolihub.icu
=======================================================""")
print(COPYRIGHT)
time.sleep(1)

CONFIG_PATH = Path('.') / 'config.yml'
config = load_yaml(CONFIG_PATH)
config = config['bot']

LOGGER_INFO_PATH = Path(
    '.'
) / 'logs' / 'info' / f"{datetime.datetime.now().strftime('%Y%m%d-%H%M%S')}-INFO.log"
LOGGER_ERROR_PATH = Path(
    '.'
) / 'logs' / 'error' / f"{datetime.datetime.now().strftime('%Y%m%d-%H%M%S')}-ERROR.log"

_app = None


class Service:
    def init(self) -> None:
        global _app
        logger.info('ATRI is initializing...')
        nonebot.init(debug=bool(config['debug']),
                     superusers=set(config['superusers']),
                     nickname=set(config['nickname']),
                     command_start=set(config['command_start']),
                     command_sep=set(config['command_sep']))

        _app = nonebot.get_asgi()

        nonebot.load_plugins('ATRI/plugins')

        logger.add(LOGGER_INFO_PATH,
                   rotation='10 MB',
                   diagnose=False,
                   level='INFO',
                   format=default_format)
        logger.add(LOGGER_ERROR_PATH,
                   rotation='10 MB',
                   diagnose=False,
                   level='ERROR',
                   format=default_format)

    def run(self) -> None:
        logger.info("Running ATRI...")
        nonebot.get_driver().run(app='ATRI:_app', # type: ignore
                                 host=config['host'],
                                 port=config['port'])