.. | ||
icon | ||
README.md | ||
testflight.js | ||
testflight.lnplugin | ||
testflight.sgmodule | ||
testflight.snippet | ||
testflight.stoverride |
TestFlight
前言
TestFlight多账户共存与自动加入脚本,主要满足个人需要两个脚本共存的需求。
感谢NobyDa、DecoAri、chouchoui、lodepuly等大佬的源代码。
本脚本部分参考了上述大佬的脚本源代码。
相对于原版,做了以下改动:
TestFlight 自动加入
- 支持NodeJS,含青龙面板
- 支持多账户
- 支持MITM Over HTTP/1.1 与 HTTP/2
- 支持控制加入TF的并发数量
- 支持Session失效检测
- 支持满员的TF自动加入任务
- 支持温和、标准和暴力三种加入模式
- 标准模式下,支持指定账号检测TF可否加入
TestFlight 多账户共存
- 支持多账户同步
- 去除共享功能
- 保留当前账户“以前测试过”的列表
部署
Surge
https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.sgmodule
Quantumult X
https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.snippet
Loon
https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.lnplugin
Stash
https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.stoverride
入门
安装对应的模块/重写/插件/覆写
TestFlight 多账户共存
在AppStore中切换不同的账号,每切换一个账号需要重新打开TestFlight,直至弹出获取必要信息成功的通知。
随后即可在TestFlight App中查看所有共存账号的App。
TestFlight 自动加入
在AppStore中登录需要加入TestFlight的账号,打开TestFlight,弹出获取必要信息成功的通知。
打开需要加入的TestFlight App链接,如果已满员会自动加入任务列表。
脚本主要运行平台为青龙面板,所以在默认的配置中不带有计划任务。需要根据运行平台不同,手动为脚本设置一个定时任务。
Surge
[Script]
TestFlight_自动加入 = type=cron,cronexp=0/5 * * * * *,script-path=https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.js
Quantumult X
[task_local]
0/5 * * * * * https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.js, tag=TestFlight_自动加入, enabled=true
Loon
[Script]
cron "0/5 * * * * *" script-path=https://raw.githubusercontent.com/blackmatrix7/ios_rule_script/master/script/testflight/testflight.js,timeout=5,TestFlight_自动加入
Stash
cron:
script:
- name: testflight.js
cron: '0/5 * * * * *'
argument: ''
timeout: 10
青龙面板
在Web界面中,选择“定时任务”,选择新增,定时规则为“*/5 * * * * *”,即5秒运行一次。
大功告成
如果你不想太过折腾,那么到这来配置就结束了,不需要再往下阅读。
进阶
TestFlight 多账户共存
多设备互相同步
脚本支持通过青龙面板,将多账户共存的信息在不同设备、不同客户端间互相同步。
举个例子,你有几台iPhone、iPad,它们使用不同的客户端,但是都使用同个脚本,连接同个青龙面板。那么当开启“同步数据到青龙面板”时,TestFlight的账户数据会在多个设备间互相同步。
更具体地说,你在iPhone上,登录A、B两个账号;在iPad上,登录C、D两个账号。开启同步后,你的iPhone、iPad和青龙面板将同时存储A、B、C、D四个账号的信息。这样无论你打开哪台设备的TestFlight的App,它们的数据是完全一致的。
当然,你也可以一台iPhone登录国区账号,一台iPhone登录外区账号,两台间互相同步。
特别说明
- 数据同步可能会影响TestFlight的加载速度,建议只在必要时开启。
- 如果多设备间数据冲突时,以青龙面板中存储的数据为准。
- 如果需要删除某个账号,需要在青龙面板的magic.json文件中删除,在iOS设备中删除无效,下次还会从青龙面板同步回来。
TestFlight 自动加入
手动编辑需要加入的AppId
通过tf_app_id
变量来存储需要加入的AppId,以;分隔。你可以在BoxJS,或magic.json文件中编辑它。
需要注意原版是以,分隔,此处配置不同。
同步至青龙面板
https://github.com/blackmatrix7/ios_rule_script/tree/master/script#readme
根据上述文档,配置青龙面板,然后在BoxJS中打开同步至青龙面板的开关。配置完成后,每次打开TestFlight,登录信息变化时都会同步到青龙面板中。同时,在打开已满员的Beta链接时,也会将App ID同步至青龙面板。
特别说明
- TestFlight中的App ID与青龙面板的同步是单向的,只能从设备同步到青龙面板。
- 青龙面板最终存储的App ID为所有设备同步数据的合集。
并发数量
指当App的Beta为可加入状态时,每个账户并发多少个请求来尝试加入。默认为2个,并发数量并不是越高越好。
三种模式的区别
温和
查询App的Beta状态时,不携带用户信息,仅在App可加入时才会使用存储的用户信息发起申请,理论上可以极大减少AppleID被Ban的几率。缺点为ResponeBody较大,查询的速度相较标准模式可能会稍慢。
此模式未经验证。
标准
默认采用标准模式。
同原版一致的逻辑,查询App的Beta状态时,会带入一个用户的信息进行查询。在App可加入时,使用存储的用户信息发起申请。缺点是每次查询都会携带用户信息,理论上有导致AppleID被Ban的风险,不过目前并无先例。
你可以指定一个小号专门用于检测可用性,具体见后文。
暴力
不查询App的Beta状态,直接使用存储的用户信息申请加入,如果无法加入会引发409的异常。优点是没有查询过程,抢App的Beta测试员成功率可能会更高。缺点是会持续不断的产生异常的请求,理论上被Ban的风险最大。
此模式未经过验证。慎选,建议使用新注册的账号试验。
多账户自动加入
可以通过在iOS的设置中,切换AppStore账户,再打开TestFlight App来实现多账户加入。
多账户并不能提高加入的成功率,相反因为需要尝试加入的账户数量变多,反而会降低成功率。
多账户存储的数据格式如下,其中类似"xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"为AccountId,非常重要,务必记牢。
"tf_session_info": {
"magic_session": true,
"xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx": {
"X-Session-Id": "xxxxxxxxxxxxxxxx",
"X-Session-Digest": "xxxxxxxxxxxxxx",
"X-Request-Id": "xxxxxxxxxxxxx"
},
"xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxoo": {
"X-Session-Id": "xxxxxxxxxxxxx",
"X-Session-Digest": "xxxxxxxxxxxxxx",
"X-Request-Id": "xxxxxxxxxxxxx"
}
}
不同账户加入不同的App Beta测试员
脚本通过tf_joined_app_id
存储的数据来判断哪些账户需要加入哪些AppID。
tf_joined_app_id的数据格式如下:
"tf_joined_app_id": {
"magic_session": true,
"xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx": [
"*",
"PTbaSXrf",
"J3awzdqd",
"aL5ZWE8A",
"iSTXkF4K"
],
"xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxoo": [
"*"
]
}
magic_session 不可修改和删除,xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx为你的账户AccountId,对应的数组则是已经加入成功的AppId。
假设不想让AccountId为xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx的账户加入PTbaSXrf的测试,在对应的数组中写入AppId即可。此时如果存在其他账户,则其他账户依旧会尝试加入PTbaSXrf的测试,直至成功。
如果某个账户,不希望它加入任何TF,则给它加一个"*",表示任何APP的测试都不加入。
专用账户检查TF
在标准模式下,可以指定一个账号专门用于检查App的TestFlight是否可加入。在BoxJS或magic.json中,为tf_check_account_id
这个变量分配一个account id,将这个账户用来检查App的Beta成员是否已满。只有当Beta可加入时,才会用真正的账户来尝试加入,以达到保护主账号的目的。
举个例子,你可以注册一个新的账号,专门用于检查TF可否加入,当可以加入时,再用你的主账号尝试加入。
需要注意的是以下几点:
- 专门用于检查的账号也需要获取Session,同时这个账号也会尝试加入TF,除非你根据上一条的
tf_joined_app_id
配置,排除掉。 - 不用于检查的主账号,最好隔段时间就刷新一下Session,以免会话过期。
连续运行
配置tf_loop_count
来设置脚本每次启动时,执行多少次任务再退出,每次任务间隔固定800毫秒。通过配置连续运行次数,可以减少青龙面板的脚本执行频次,避免因为日志过多导致青龙面板没有响应。
如果是NodeJS环境(非青龙面板),可以设置为0,脚本将持续运行不会终止。
不要在手机上将tf_loop_count
设置为0,否则脚本会一直运行直到超时,或被手动中止。
Session检测
因为脚本的主要运行环境是青龙面板,所以可能存在Session因为长期未更新导致失效的情况。为此加入每2小时检测一次Session有效期的功能,如果失效会推送通知到手机,需要再手动获取信息,并同步到青龙面板。
检测间隔可以通过变量tf_check_session_time_diff
配置,单位秒,不要配置过短,以免影响脚本正常功能。
其他
如果有问题欢迎反馈。
Loon暂不支持MITM Over HTTP/2
已经和作者反馈,需要等待Loon更新。
Shadowrocket未经验证
Shadowrocket未经验证,不确保能够正常使用
脚本变量
当前脚本使用的变量,你可以根据这些Key,在magic.json中配置数据。
名称 | 类型 | 默认值 | 说明 |
---|---|---|---|
tf_session_info | Json | 无 | 由脚本自动获取的Session信息,如需修改请整个删除重新获取 |
tf_app_id | String | 无 | 需要加入Beta的AppId,多个以;分隔 |
tf_join_mode | Int | 1 | 执行默认 0 温和 1 标准 2 暴力 |
tf_join_concurrency | Int | 2 | 每个账户并发加入TestFlight Beta测试员的请求数 |
tf_joined_app_id | Json | 无 | 存储每个账户已经成功加入的AppId |
tf_check_account_id | String | 无 | 专门用于检查TF可用性的Id,如果为空则从已登录的账户中随机选择 |
tf_loop_count | Int | 1 | 每次运行脚本时循环多少次,每次循环间隔800毫秒,NodeJS(非青龙面板)可设置为0,表示持续运行 |
tf_check_session_time_diff | Int | 7200 | 每间隔多少秒检查一次账户的有效性,默认7200秒 |
tf_check_session_time | Int | 无 | 上次检查账户有效期的时间,自动生成,不需要配置 |
tf_invalid_app_id | Json | 无 | 验证无效的AppId,自动生成,不需要配置 |