Searcher 分为前端和后端两个部分。后端部分是一个 userbot,使用一个普通用户的账号,负责获取 Telegram 中会话的消息,并且将其存入硬盘中的索引。Userbot 和 Telegram 的登录记录被称为 session。
前端负责处理和用户的交互,它可以有多种实现,目前实现了 Telegram bot 的前端。用户通过和这个 bot 账号对话来和后端进行交互,一般的用户可以通过 bot 来搜索消息;管理员除了可以用来搜索消息之外,还可以用它来管理后端的数据。
Searcher 使用 YAML 作为配置文件的格式,默认的配置文件位于 ./searcher.yaml
,用户可以通过命令行参数指定其它的配置文件位置。
在填写配置文件之前,有下面几项准备工作:
- 在 my.telegram.org 申请一对
api_id
和api_hash
- 如果使用 bot 前端,需要向 BotFather 申请一个 bot 账号,获取它的
bot_token
,为了确保管理员能收到 bot 发来的消息,申请之后给 bot 发送一条任意的消息。 - 找到管理员的用户 ID,可以通过向 GetIDs Bot 发送任意消息来获取自己的用户 ID。
以下是一个最简单的配置文件,注意其中的各个 id 需要修改成用户自己的对应 id:
common:
name: sharzy_test
runtime_dir: /var/lib/tg_searcher
api_id: 1234567
api_hash: 17a89121c4347182b112e15c1517a998
sessions:
- name: alice
phone: '+18352436375'
backends:
- id: pub_index
use_session: alice
frontends:
- type: bot
id: public
use_backend: pub_idx
config:
admin_id: 619376577
bot_token: 1200617810:CAF930aE75Vbac02K34tR-A8abzZP4uAq98
以下是一个完整的配置文件,包含了所有的可配置项和对应的注释。
common:
# 当前 Searcher 实例的名称,防止部署多个实例的时候文件冲突
name: sharzy_test
# 运行时存储索引文件、session 文件等的位置,多个实例可以使用相同的位置
runtime_dir: /var/lib/tg_searcher
# 用于访问 Telegram 的代理,支持 socks5 和 http 协议,如不需要可以去掉该行
proxy: socks5://localhost:1080
api_id: 1234567
api_hash: 17a89121c4347182b112e15c1517a998
sessions:
- name: alice # 用来标识 session 的名称,在配置文件中唯一即可
phone: '+18352436375' # 用户的电话号码
backends:
- id: pub_index # 用来标识后端的名称,在配置文件中唯一即可
use_session: alice # 后端所使用的 session 的名称
- id: priv_idx
use_session: alice
config:
monitor_all: true # 当启用这一选项的时候,所有的会话均会被监听,新消息全部会被加入索引
excluded_chats: # 当 monitor_all 选项启用的时候,这个列表里的会话不会被监听
- 342843148
- 857204339
frontends:
- type: bot # 目前只支持 bot 类型的前端
id: public
use_backend: pub_index # 使用的后端的名称
config:
admin_id: 619376577 # 管理员的用户 ID
bot_token: 1200617810:CAF930aE75Vbac02K34tR-A8abzZP4uAq98
page_len: 10 # 搜索时每页显示的结果数量,默认为 10
redis: localhost:6379 # Redis 服务器的地址,默认为 localhost:6379
no_redis: localhost:6379 # 不使用 Redis 来持久化部分用户数据
- type: bot
id: private
use_backend: priv_idx
config:
admin_id: 619376577
# 不同前端应该使用不同的 bot_token
bot_token: 2203317382:BkF390ab92kcb1b2ii2b4-1sbc39i20bb12
redis: localhost:6379 # Redis 服务器的地址,默认为 localhost:6379
# 如果开启了 private_mode,那么只有 private_whitelist 里的用户才能使用 bot
# 管理员默认位于 private_whitelist 中,无需额外添加
private_mode: true
private_whitelist:
- 719376577