mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 21:52:56 +08:00
* ✨ feat(core): 更新群组信息、Markdown 样式与 Pydantic 兼容层 - 【group】添加更新所有群组信息指令,并同步群组控制台数据 - 【markdown】支持合并 Markdown 的 CSS 来源 - 【pydantic-compat】提供 model_validate 兼容函数 * ✨ feat(core): 增强定时任务与群组标签管理,重构调度核心 ✨ 新功能 * **标签 (tags)**: 引入群组标签服务。 * 支持静态标签和动态标签 (基于 Alconna 规则自动匹配群信息)。 * 支持黑名单模式及 `@all` 特殊标签。 * 提供 `tag_manage` 超级用户插件 (list, create, edit, delete 等)。 * 群成员变动时自动失效动态标签缓存。 * **调度 (scheduler)**: 增强定时任务。 * 重构 `ScheduledJob` 模型,支持 `TAG`, `ALL_GROUPS` 等多种目标类型。 * 新增任务别名 (`name`)、创建者、权限、来源等字段。 * 支持一次性任务 (`schedule_once`) 和 Alconna 命令行参数 (`--params-cli`)。 * 新增执行选项 (`jitter`, `spread`) 和并发策略 (`ALLOW`, `SKIP`, `QUEUE`)。 * 支持批量获取任务状态。 ♻️ 重构优化 * **调度器核心**: * 拆分 `service.py` 为 `manager.py` (API) 和 `types.py` (模型)。 * 合并 `adapter.py` / `job.py` 至 `engine.py` (统一调度引擎)。 * 引入 `targeting.py` 模块管理任务目标解析。 * **调度器插件 (scheduler_admin)**: * 迁移命令参数校验逻辑至 `ArparmaBehavior`。 * 引入 `dependencies.py` 和 `data_source.py` 解耦业务逻辑与依赖注入。 * 适配新的任务目标类型展示。 * 🐛 fix(tag): 修复黑名单标签解析逻辑并优化标签详情展示 * ✨ feat(scheduler): 为多目标定时任务添加固定间隔串行执行选项 * ✨ feat(schedulerAdmin): 允许定时任务删除、暂停、恢复命令支持多ID操作 * 🚨 auto fix by pre-commit hooks --------- Co-authored-by: webjoin111 <455457521@qq.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
57 lines
2.2 KiB
Python
57 lines
2.2 KiB
Python
from tortoise import fields
|
|
|
|
from zhenxun.services.db_context import Model
|
|
|
|
|
|
class ScheduledJob(Model):
|
|
id = fields.IntField(pk=True, generated=True, auto_increment=True)
|
|
name = fields.CharField(
|
|
max_length=255, null=True, description="任务别名,方便用户辨识"
|
|
)
|
|
created_by = fields.CharField(
|
|
max_length=255, null=True, description="创建任务的用户ID"
|
|
)
|
|
required_permission = fields.IntField(
|
|
default=5, description="管理此任务所需的最低权限等级"
|
|
)
|
|
source = fields.CharField(
|
|
max_length=50, default="USER", description="任务来源 (USER, PLUGIN_DEFAULT)"
|
|
)
|
|
|
|
bot_id = fields.CharField(
|
|
255, null=True, description="执行任务的Bot约束 (具体Bot ID或平台)"
|
|
)
|
|
plugin_name = fields.CharField(255, description="插件模块名")
|
|
target_type = fields.CharField(
|
|
max_length=50, description="目标类型 (GROUP, USER, TAG, ALL_GROUPS, GLOBAL)"
|
|
)
|
|
target_identifier = fields.CharField(
|
|
max_length=255, description="目标标识符 (群号, 标签名等)"
|
|
)
|
|
|
|
trigger_type = fields.CharField(
|
|
max_length=20, default="cron", description="触发器类型 (cron, interval, date)"
|
|
)
|
|
trigger_config = fields.JSONField(description="触发器具体配置")
|
|
job_kwargs = fields.JSONField(
|
|
default=dict, description="传递给任务函数的额外关键字参数"
|
|
)
|
|
|
|
is_enabled = fields.BooleanField(default=True, description="是否启用")
|
|
is_one_off = fields.BooleanField(default=False, description="是否为一次性任务")
|
|
last_run_at = fields.DatetimeField(null=True, description="上次执行完成时间")
|
|
last_run_status = fields.CharField(
|
|
max_length=20, null=True, description="上次执行状态 (SUCCESS, FAILURE)"
|
|
)
|
|
consecutive_failures = fields.IntField(default=0, description="连续失败次数")
|
|
execution_options = fields.JSONField(
|
|
null=True,
|
|
description="任务执行的额外选项 (例如: jitter, spread, "
|
|
"interval, concurrency_policy)",
|
|
)
|
|
create_time = fields.DatetimeField(auto_now_add=True)
|
|
|
|
class Meta: # type: ignore
|
|
table = "scheduled_tasks"
|
|
table_description = "通用定时任务定义表"
|