One-Key-Publish,一键发布 Torrent 到常见 BT 站。
如果需要图形界面,可以尝试使用 OKPGUI。
- 导出并添加 Cookie 参考这里,默认的 cookie 文件将保存在程序目录的
config\cookies
目录下。 - 编写一个配置文件 示例,将配置文件置于种子文件同目录下。
- 拖动你的种子文件到 OKP.exe 上以发布你的资源,OKP 将自动寻找 cookie 文件与配置文件。
OKP.Core yourTorrent.torrent {-s yourSetting.toml} {--cookies yourCookieFile.txt}
Description:
One Key Publish
Usage:
okp [<torrent>...] [options]
Arguments:
<torrent> Torrents to be published. (Or Cookie file exported by Get Cookies.txt.)
Options:
-?, -h, --help Show help and usage information
--version Show version information
--cookies Cookie file to be used. []
-s, --setting (Not required) Specific setting file. [default: setting.toml]
-l, --log_level Log level. [default: Debug]
--log_file Log file. [default: log.txt]
-y, --no_reaction Skip reaction.
--allow_skip Ignore login fail and continue publishing.
-b, --base_template Base template. It needs to be a markdown file, and other site templates will be generated based on it which missing publishing content. []
你必须输入一个 Torrent 种子文件
- 注意 Torrent V2 不受支持
或者
一个包含 cookie 信息的 txt 文件
- 你需要使用 Get cookies.txt LOCALLY 这个 Chrome 扩展来导出 txt。
--cookies
,输入一个 cookie,若不指定则为config\cookies
目录下的cookies.txt
-s, --setting
,输入一个配置文件,若不指定则为 Torrent 同目录下的setting.toml
-l, --log_level
,指定输出的 log level,默认是Debug
,可以指定Verbose, Debug, Info
(不区分大小写)--log_file
,指定输出的 log 文件,默认命名为log{当前时间的4位年份}{当前时间的2位月份}.txt
,默认输出位置为执行目录-y
,跳过所有需要回车的地方--allow_skip
,如果有站点登录失败则自动跳过-b, --base_template
,在没有填写发布内容时,可以指定一个 markdown 文件,发布内容由这个 markdown 进行转换生成
首先是个 .toml
配置文件,示例
display_name
:BT 站发布标题,有<ep>
与<res>
两个可配置标签,可用正则表达式从 Torrent 文件名中提取出集数与分辨率并自动填充
<ep>
:使用filename_regex
中指定的正则表达式提取集数<res>
:使用resolution_regex
中指定的正则表达式提取分辨率
filename_regex
:一个合法的正则表达式,并将集数放入名为<?ep>
的命名分组中resolution_regex
:一个合法的正则表达式,并将集数放入名为<?res>
的命名分组中
group_name
:不知道有啥用poster
:海报链接,会用在 BT 发布中需要提供图片的非正文部分about
:关于 / 联系方式 / 报错链接等,会用在 BT 发布中相应的非正文部分
tags
: 一个用于描述资源分类的 List。全部可用的类型请参照 OKP.Core.Interface.TorrentContent.ContentTypes。你可以添加任意数量的 tag,这些 tag 会根据各发布站的规则自动映射到对应分类,详见 tags 映射。
都在 [[intro_template]]
中
site
:发布站名,具体见 支持站点name
:发布用账户名称或发布用组织名称- acgnx 站点使用 api 的 uid
proxy
:连接站点使用的代理content
:发布正文,可以指定一个文件名或 raw string- 指定文件名的后缀同见 #支持站点
- 如果配合
-b, --base_template
使用可以不用填写
同见 支持站点
- 安装Get Cookies.txt
- 正常登录对应的发布站。目前已经支持的站点同见 支持站点
- 点击扩展中的
Export
或Export as
导出同站点下的全部 Cookie。由于 C# 中 Cookie 容器最大仅支持 300 条 Cookie 同时存在,不推荐一次性导出浏览器中的全部 Cookie。 如果你导出了動漫花園的 Cookie,你需要在 txt 中删掉多余记录,仅保留pass; rsspass; tid; uname; uid
共 5 行记录。如果你忘记在 txt 中删除多余记录,你可以在导出完成的cookie.txt
文件中删除多余记录。- OKP 支持一次添加多个 Cookie 文件,所有的 Cookie 都导出完成后,多选全部 txt 文件,并拖拽到
OKP.exe
上。 - 你需要输入一个文件名来保存的准备导入的 Cookie,默认文件名为
cookie
。 - 你需要输入你的浏览器 User-Agent 来确保你的 Cookie 可以正常工作。如果你不知道如何获取你的 User-Agent,你可以访问 这里。
- OKP 会自动添加 Cookie,当一个文件添加完成时,你需要回车确认并继续。
- 添加完成后,具有 Cookie 记录的文件将会保存在程序目录中的
config\cookies
目录下,默认文件名为cookie.txt
或你指定的文件名。
- cookie 文件默认保存在
OKP.exe
同目录下,文件名为cookie.txt
。 - 你可以在
publish template
中指定任意的 Cookie 文件。 - 正常情况下所有 Cookie 均会自动更新并保存。当 Cookie 失效并且无法自动刷新时,你可以直接添加对应 Cookie,OKP 会自动处理并管理这些 Cookie。
需要放在使用的应用程序同级的 config
目录下,文件名为 userprop.toml
,示例
可以使用它来指定一些不方便写在 setting 中的敏感信息,现在支持 proxy
和 cookie
(可以用来指定 acgnx 的 api token)。二者同时指定时,userprop 中的数据会覆盖 setting 的数据。
想要替换 / 指定的配置需要与 setting 中的 site
和 name
相同
以下排名无先后
站点 | 配置名称 | 模板格式与示例 |
---|---|---|
Nyaa | nyaa | .md |
動漫花園 | dmhy | .html |
ACG.RIP | acgrip | .bbcode |
末日動漫資源庫 | acgnx_asia | .html |
AcgnX Torrent Global | acgnx_global | .html |
萌番组 | bangumi | .html |
最新支持站点请看 这
注:
- acgrip cookie 失效后会刷新,退出登录疑似会直接失效,ua 不同也会登录失败。
- acgnx 站点登录可能会被 Cloudflare 风控,鉴于其站点会同步 nyaa、dmhy、acgrip 的种子,可以选择不使用其上传。
- 萌番组暂不支持自定义 TAG,目前仅支持 Team ID 和 setting 中 tags 映射的分类两个 TAG。
動漫花園必须删除多余的 Cookie,否则无法登录。
- 如果你只有一个发布身份 / 账号,将所有账号的 Cookie 保存在同一个 Cookie 文件中。
- 如果你有多个发布身份 / 账号,将同一个身份的 Cookie 保存在同一个 Cookie 文件中,并以账户名命名你的 Cookie 文件。
- 尽可能全面的设置你的 Tags,以便在各发布站准确映射到对应分类。
- 如果发布站的模板格式相同,例如 dmhy 和 acgnx,使用同一个模板文件。
- 将配置文件与种子放置在同一个目录,或者自行编写一个批处理文件处理输入参数,以方便你拖动种子文件进行发布。
- 将 Cookie 视为你的账户密码并妥善保护,任何获取到 Cookie 文件的人都可以轻易登录你的账户。
- 在配置文件中尽可能的使用相对目录,来避免潜在的信息泄露。
- 由于 OKP 将直接使用你的账户进行敏感操作,如果你不信任 OKP,请自行审计源码,并从 Github Action 下载最新的 Build。
删除 cookie 文件重新添加。
删除 cookie 文件,使用浏览器登录后,访问发布页面(例如),在发布页面重新导出 cookie 后再导入。
重新进行发布。由于绝大多数发布站都具有检测重复资源的机制,OKP 将会尝试重新在所有已配置的发布站进行发布。
去提个 issue,不出意外你的 issue 会出现在这里。