92 lines
2.6 KiB
Python
92 lines
2.6 KiB
Python
#! /usr/bin/env python3
|
||
# -*- coding: utf-8 -*-
|
||
import threading
|
||
from configuration import Config
|
||
from robot import Robot
|
||
|
||
from loguru import logger
|
||
|
||
# INFO 日志(包含 INFO、DEBUG,但不包含 WARNING、ERROR)
|
||
logger.add(
|
||
f"wx_info.log",
|
||
level="INFO",
|
||
filter=lambda record: record["level"].name in ["INFO", "DEBUG"],
|
||
rotation="10 MB",
|
||
retention="7 days",
|
||
encoding="utf-8"
|
||
)
|
||
|
||
# ERROR 日志(仅 ERROR 及以上)
|
||
logger.add(
|
||
f"wx_error.log",
|
||
level="ERROR",
|
||
rotation="10 MB",
|
||
retention="7 days",
|
||
encoding="utf-8"
|
||
)
|
||
# ERROR 日志(仅 ERROR 及以上)
|
||
logger.add(
|
||
f"wx_debug.log",
|
||
level="DEBUG",
|
||
rotation="10 MB",
|
||
retention="7 days",
|
||
encoding="utf-8"
|
||
)
|
||
|
||
|
||
def main():
|
||
config = Config()
|
||
|
||
# 创建机器人实例
|
||
robot = Robot(config)
|
||
robot.LOG.info(f"WeChatRobot 正在启动...")
|
||
|
||
# 初始化并启动wechat_ipad客户端
|
||
if robot.init_wechat_ipad():
|
||
robot.LOG.info("wechat_ipad客户端启动成功")
|
||
else:
|
||
robot.LOG.error("wechat_ipad客户端启动失败")
|
||
# # 每天 8:30 发送新闻
|
||
robot.onEveryTime("08:30", robot.news_baidu_report_auto)
|
||
#
|
||
# # epic
|
||
robot.onEveryTime("10:30", robot.send_epic_free_games)
|
||
#
|
||
# # message report 1:数据自动从redis 转到sqllite
|
||
robot.onEveryTime("02:30", robot.message_count_to_db)
|
||
# # 从db中提取并发送给相关群
|
||
robot.onEveryTime("09:30", robot.generate_and_send_ranking)
|
||
#
|
||
# # sehuatang
|
||
robot.onEveryTime("15:30", robot.generate_sehuatang_pdf)
|
||
#
|
||
# # 秀人网每天自动下载帖子
|
||
robot.onEveryTime("01:30", robot.xiu_ren_download_task)
|
||
#
|
||
# # 秀人网每天自动发pdf
|
||
# robot.onEveryTime("17:30", robot.xiu_ren_pdf_send)
|
||
|
||
# 每天进行二次登录检查
|
||
robot.onEveryHours(3, robot.login_twice_auto_auth)
|
||
|
||
# 启动Dashboard服务器
|
||
dashboard_server = None
|
||
try:
|
||
# 创建Dashboard服务器实例,共享robot对象
|
||
from admin.dashboard.server import DashboardServer
|
||
dashboard_server = DashboardServer(robot_instance=robot)
|
||
|
||
# 在单独的线程中启动Dashboard服务器
|
||
dashboard_thread = threading.Thread(target=dashboard_server.run, daemon=True)
|
||
dashboard_thread.start()
|
||
robot.LOG.info(f"Dashboard服务器已在 http://{dashboard_server.host}:{dashboard_server.port} 启动")
|
||
except Exception as e:
|
||
robot.LOG.error(f"Dashboard服务器启动失败: {e}")
|
||
|
||
# 让机器人一直跑
|
||
robot.keep_running_and_block_process()
|
||
|
||
|
||
if __name__ == "__main__":
|
||
main()
|