Skip to content

AmusementClub/OKP

Repository files navigation

OKP

One-Key-Publish,一键发布 Torrent 到常见 BT 站。

如果需要图形界面,可以尝试使用 OKPGUI

Quick Start

依赖:.NET 8 Runtime

  1. 导出并添加 Cookie 参考这里,默认的 cookie 文件将保存在程序目录的 config\cookies 目录下。
  2. 编写一个配置文件 示例,将配置文件置于种子文件同目录下。
  3. 拖动你的种子文件到 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 文件

可选项

  • --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 进行转换生成

配置文件

setting

首先是个 .toml 配置文件,示例

发布标题相关

  1. display_name:BT 站发布标题,有 <ep><res> 两个可配置标签,可用正则表达式从 Torrent 文件名中提取出集数与分辨率并自动填充
  • <ep>:使用 filename_regex 中指定的正则表达式提取集数
  • <res>:使用 resolution_regex 中指定的正则表达式提取分辨率
  1. filename_regex:一个合法的正则表达式,并将集数放入名为 <?ep> 的命名分组中
  2. resolution_regex:一个合法的正则表达式,并将集数放入名为 <?res> 的命名分组中

发布用其他信息

  1. group_name:不知道有啥用
  2. poster:海报链接,会用在 BT 发布中需要提供图片的非正文部分
  3. about:关于 / 联系方式 / 报错链接等,会用在 BT 发布中相应的非正文部分

发布分类相关

  1. tags: 一个用于描述资源分类的 List。全部可用的类型请参照 OKP.Core.Interface.TorrentContent.ContentTypes。你可以添加任意数量的 tag,这些 tag 会根据各发布站的规则自动映射到对应分类,详见 tags 映射

发布站点与正文

都在 [[intro_template]]

  1. site:发布站名,具体见 支持站点
  2. name:发布用账户名称或发布用组织名称
    • acgnx 站点使用 api 的 uid
  3. proxy:连接站点使用的代理
  4. content:发布正文,可以指定一个文件名或 raw string
    • 指定文件名的后缀同见 #支持站点
    • 如果配合 -b, --base_template 使用可以不用填写

publish template

同见 支持站点

导入 Cookie 到 OKP

  1. 安装Get Cookies.txt
  2. 正常登录对应的发布站。目前已经支持的站点同见 支持站点
  3. 点击扩展中的ExportExport as导出同站点下的全部 Cookie。由于 C# 中 Cookie 容器最大仅支持 300 条 Cookie 同时存在,不推荐一次性导出浏览器中的全部 Cookie。
  4. 如果你导出了動漫花園的 Cookie,你需要在 txt 中删掉多余记录,仅保留 pass; rsspass; tid; uname; uid 共 5 行记录。如果你忘记在 txt 中删除多余记录,你可以在导出完成的 cookie.txt 文件中删除多余记录。
  5. OKP 支持一次添加多个 Cookie 文件,所有的 Cookie 都导出完成后,多选全部 txt 文件,并拖拽到 OKP.exe 上。
  6. 你需要输入一个文件名来保存的准备导入的 Cookie,默认文件名为 cookie
  7. 你需要输入你的浏览器 User-Agent 来确保你的 Cookie 可以正常工作。如果你不知道如何获取你的 User-Agent,你可以访问 这里
  8. OKP 会自动添加 Cookie,当一个文件添加完成时,你需要回车确认并继续。
  9. 添加完成后,具有 Cookie 记录的文件将会保存在程序目录中的 config\cookies 目录下,默认文件名为 cookie.txt 或你指定的文件名。

使用 OKP 中的 Cookie 信息

  • cookie 文件默认保存在 OKP.exe 同目录下,文件名为 cookie.txt
  • 你可以在 publish template 中指定任意的 Cookie 文件。
  • 正常情况下所有 Cookie 均会自动更新并保存。当 Cookie 失效并且无法自动刷新时,你可以直接添加对应 Cookie,OKP 会自动处理并管理这些 Cookie。

userprop (实验性功能,将会在未来版本被移除)

需要放在使用的应用程序同级的 config 目录下,文件名为 userprop.toml示例

可以使用它来指定一些不方便写在 setting 中的敏感信息,现在支持 proxycookie(可以用来指定 acgnx 的 api token)。二者同时指定时,userprop 中的数据会覆盖 setting 的数据。

想要替换 / 指定的配置需要与 setting 中的 sitename 相同

支持站点

以下排名无先后

站点 配置名称 模板格式与示例
Nyaa nyaa .md
動漫花園 dmhy .html
ACG.RIP acgrip .bbcode
末日動漫資源庫 acgnx_asia .html
AcgnX Torrent Global acgnx_global .html
萌番组 bangumi .html

最新支持站点请看

注:

  1. acgrip cookie 失效后会刷新,退出登录疑似会直接失效,ua 不同也会登录失败。
  2. acgnx 站点登录可能会被 Cloudflare 风控,鉴于其站点会同步 nyaa、dmhy、acgrip 的种子,可以选择不使用其上传。
  3. 萌番组暂不支持自定义 TAG,目前仅支持 Team ID 和 setting 中 tags 映射的分类两个 TAG。
  4. 動漫花園必须删除多余的 Cookie,否则无法登录。

最佳实践

  • 如果你只有一个发布身份 / 账号,将所有账号的 Cookie 保存在同一个 Cookie 文件中。
  • 如果你有多个发布身份 / 账号,将同一个身份的 Cookie 保存在同一个 Cookie 文件中,并以账户名命名你的 Cookie 文件。
  • 尽可能全面的设置你的 Tags,以便在各发布站准确映射到对应分类。
  • 如果发布站的模板格式相同,例如 dmhy 和 acgnx,使用同一个模板文件。
  • 将配置文件与种子放置在同一个目录,或者自行编写一个批处理文件处理输入参数,以方便你拖动种子文件进行发布。
  • 将 Cookie 视为你的账户密码并妥善保护,任何获取到 Cookie 文件的人都可以轻易登录你的账户。
  • 在配置文件中尽可能的使用相对目录,来避免潜在的信息泄露。
  • 由于 OKP 将直接使用你的账户进行敏感操作,如果你不信任 OKP,请自行审计源码,并从 Github Action 下载最新的 Build。

常见问题

导入了 Cookie 后无法访问某个发布站

删除 cookie 文件重新添加。

已经重新添加了,还是无法访问某个发布站(例如 acg.rip)

删除 cookie 文件,使用浏览器登录后,访问发布页面(例如),在发布页面重新导出 cookie 后再导入。

某个发布站发布失败

重新进行发布。由于绝大多数发布站都具有检测重复资源的机制,OKP 将会尝试重新在所有已配置的发布站进行发布。

其他问题

去提个 issue,不出意外你的 issue 会出现在这里。

About

One-Key-Publish,一键发布Torrent到常见BT站。

Resources

License

Stars

Watchers

Forks

Packages

No packages published