tsschecker is a powerful tool to check TSS signing status of various devices and iOS versions.
Latest compiled version can be found here:
(MacOS + Linux + Windows)
http://api.tihmstar.net/builds/tsschecker/tsschecker-latest.zip
Windows support has stopped.
Follow this guide to use tsschecker on Ubuntu 18.04 (Bionic) as it requires libcurl3 which cannot coexist with libcurl4 on this OS.
- Allows you to get lists of all devices and all iOS/OTA versions for a specific device.
- Can check signing status for default iOS versions and beta ipsws (by specifying a
BuildManifest.plist
) - Works without specifying any device relevant values to check signing status, but can be used to save blobs when given an ECID and the option
--print-tss-response
(although there are better tools to do this).
tsschecker is not only meant to be used to check signing status, but also to explore Apple's TSS servers. By using all of its customization possibilities, you might discover a combination of devices and iOS versions that is now getting signed but wasn't getting signed before. You can use file 'nonces.txt' to save blobs with popular ApNonces.
Those don't need to be installed manually
- tss
-
Make sure these are installed
- libcurl
- libplist
- libfragmentzip
- openssl or commonCrypto on macOS/OS X;
- libirecovery;
- Make sure these projects compile on your system
(might become outdated):
Usage: tsschecker [OPTIONS]
option (short) | option (long) | description |
---|---|---|
-d |
--device MODEL |
specify device by its MODEL (eg. iPhone4,1 ) |
-i |
--ios VERSION |
specify iOS version (eg. 6.1.3 ) |
--buildid BUILDID |
specific buildid instead of iOS version (eg. 13C75 ) |
|
-B |
--boardconfig BOARD |
specific boardconfig instead of iPhone model (eg. n61ap ) |
-h |
--help |
prints usage information |
-o |
--ota |
check OTA signing status, instead of normal restore |
-b |
--no-baseband |
don't check baseband signing status. Request a ticket without baseband |
-m |
--build-manifest MANIFEST |
manually specify buildmanifest (can be used with -d ) |
-u |
--update-install |
request update ticket instead of erase |
-s |
--save |
save fetched shsh blobs (mostly makes sense with -e) |
-l |
--latest |
use latest public iOS version instead of manually specifying one especially useful with -s and -e for saving blobs |
--apnonce NONCE |
manually specify APNONCE instead of using random one (not required for saving blobs) | |
--sepnonce NONCE |
manually specify SEPNONCE instead of using random one (not required for saving blobs) | |
--bbsnum SNUM |
manually specify BbSNUM in HEX for saving valid BBTicket | |
--generator GEN |
manually specify generator in format 0x%%16llx | |
--save-path PATH |
specify path for saving blobs | |
-e |
--ecid ECID |
manually specify an ECID to be used for fetching blobs, instead of using random ones. ECID must be either dec or hex eg. 5482657301265 or ab46efcbf71 |
--beta |
request ticket for beta instead of normal release (use with -o ) |
|
--list-devices |
list all known devices | |
--list-ios |
list all known iOS versions | |
--nocache |
ignore caches and re-download required files | |
--print-tss-request |
prints TSS request that will be sent to Apple | |
--print-tss-response |
prints TSS response that come from Apple | |
--raw |
send raw file to Apple's TSS server (useful for debugging) |