跳转至

配置与数据目录

技术栈

  • .NET 8 / ASP.NET Core / Blazor Server
  • MudBlazor
  • EF Core(默认 SQLite)
  • WTelegramClient(MTProto)

Docker 数据目录(强相关)

docker-compose.yml 会把宿主机 ./docker-data 挂载到容器 /data,核心文件包括:

  • /data/telegram-panel.db:SQLite 数据库
  • /data/sessions/:账号 session 文件
  • /data/appsettings.local.json:UI 保存后的本地覆盖配置
  • /data/admin_auth.json:后台登录账号/密码(首次会用初始默认值生成)
  • /data/uploads/:图片资产(数据字典图片、头像素材等)

后台任务(刷新页面不影响)

部分批量任务会在后台静默执行(避免“刷新页面就中断”):

  • 批量邀请
  • 批量设置管理员

账号状态检测(深度探测)

为更可靠识别冻结/受限等状态,支持深度探测(例如通过创建/删除测试频道来探测权限)。

检测结果会持久化到数据库,避免刷新页面又变回“未检测”。

清理废号(封禁/受限/未登录/session 失效)

在「账号列表」与「外置验证码链接」页面支持“清理废号”(多选批量):

  • 会先执行 Telegram 状态检测(可选普通/深度)
  • 仅当判定为废号(封禁/受限/被冻结/需要 2FA/Session 失效或损坏)才会删除
  • 删除范围:数据库记录 + *.session(含常见备份/同名 json)
  • 若遇到 *.session 文件被占用,会先尝试从 TelegramClientPool 释放客户端并重试删除

另外,系统「账号列表」支持“一键清理所有废号”(扫描系统全部账号)。

配置项速查

Docker 下常用环境变量(见 docker-compose.yml):

  • ConnectionStrings__DefaultConnection:SQLite 路径(默认 /data/telegram-panel.db
  • Telegram__SessionsPath:session 目录(默认 /data/sessions
  • AdminAuth__CredentialsPath:后台密码文件(默认 /data/admin_auth.json
  • Sync__AutoSyncEnabled:账号创建的频道/群组自动同步(默认关闭)
  • Telegram__BotAutoSyncEnabled:Bot 频道自动同步(默认关闭)
  • Telegram__WebhookEnabled:Bot Webhook 模式开关(默认关闭,使用长轮询)
  • Telegram__WebhookBaseUrl:Webhook 公网 HTTPS 地址
  • Telegram__WebhookSecretToken:Webhook 验证密钥

UI 保存到本地覆盖配置

面板里的部分“保存”按钮会把设置写入 appsettings.local.json(Docker 下为 /data/appsettings.local.json),常见键:

  • Telegram:BotAutoSyncEnabled / Telegram:BotAutoSyncIntervalSeconds:Bot 频道后台自动同步轮询开关/间隔
  • ChannelAdminDefaults:Rights:批量设置管理员的“默认权限”
  • ChannelAdminPresets:Presets:批量设置管理员的“用户名列表预设”(名称 -> usernames)
  • ChannelInvitePresets:Presets:批量邀请成员的“用户名列表预设”(名称 -> usernames)

Bot 启用/停用(每个 Bot)

机器人管理页可以对单个 Bot 启用/停用:停用后该 Bot 不会再被后台轮询 getUpdates,也不会被需要 Bot 的模块/任务使用。

Bot Webhook 模式(生产环境推荐)

Bot Webhook 的完整配置与注意事项已单独整理:见 Bot Webhook