No project description provided
Project description
TBCMailServer
A private server for the mailbox in The Battle Cats.
It allows you to get any cat, talent orb, or item amount you want without the ban risk of other methods.
Credits
- jamesiotio's CITM for the original hacking method and the format of the presents. It no longer works due to PONOS adding a signature to the server responses as well as other changes.
Prerequisites
I won't go into detail on how to do all of the individual steps such as how to extract the apk, sign it and setup Frida. You can find tutorials on how to do all of that online.
-
You will need to modify the game to always verify the nyanko-signature of the server responses as we don't know PONOS's private key. This can be done using Frida and this script:
let func_name = "_ZN5Botan11PK_Verifier14verify_messageEPKhmS2_m" // 64 bit // or let func_name = "_ZN5Botan11PK_Verifier14verify_messageEPKhjS2_j" // 32 bit // Botan::PK_Verifier::verify_message(...) Interceptor.attach(Module.findExportByName("libnative-lib.so", func_name), { onLeave: function (retval) { retval.replace(0x1) } })
Alternativly you can patch the libnative-lib.so file using a hex editor to make the function always return 1.
-
You also need to replace the
https://nyanko-items.ponosgames.com
URL in the libnative-lib.so files with your own server URL. This can be done by extracting the APK using something like apktool or APKToolGui -
Then you can modify the
libnative-lib.so
files in thelib
folder using a hex editor (or notepad maybe). -
Then you can repack the APK using apktool and sign it using apksigner or APKToolGui.
-
The URL needs to be the same length as the original URL and it needs to have /items/ at the end with underscores padding the rest of the URL.
The underscores are used to make the URL the same length as the original URL. The URL also needs to start with https and so you can use a service like Serveo to do the https part for you. Just follow the instructions on the website. I recommend you to get a custom subdomain so it doesn't change (you can use any subdomain as long as the total url length is shorter than the original URL).
Example:
You can run a command like: ssh -R myserver:80:localhost:80 serveo.net
You may need to setup ssh keys for the above to work (follow the given
instructions) This makes your url: https://myserver.serveo.net
and then you
would replace the ponos url with https://myserver.serveo.net/items/_
.
Instead of using a private server, you might be able to use something like mitmproxy or Fiddler to modify the server responses. This did not work for me as the game always crashed (works for other requests though) but it might work for you.
Installation
-
Install Python >= 3.9
-
Run
pip install -U tbcms
Usage
-
Run
python -m tbcms
orpy -m tbcms
depending on your system. -
Run
python -m tbcms --help
for more information. -
Read jamesiotio's CITM on how to format the list of presents.
-
Create a file called
presents.json
somewhere and put your presents in it. -
Run
python -m tbcms --presents path/to/presents.json
to start server.
Example presents.json
[
{
"id": 1,
"title": "Items",
"body": "Test Body",
"createdAt": 1688648392,
"items": [
{
"itemId": 22,
"itemCategory": 0,
"amount": 50,
"title": "Catfood"
},
{
"itemId": 29,
"itemCategory": 0,
"amount": 5,
"title": "Platinum Ticket"
}
]
}
]
Alternative Method
You can also change the public key the game uses to verify the server responses to your own public key from a key pair you generated.
You can modify the assets/nyanko-service-prd.pem
file in the APK to use your own
public key. You can generate a key pair using openssl:
openssl genrsa -out private.pem 4096
openssl rsa -in private.pem -pubout -out public.pem
The problem with this method is that you now need to intercept or use a private server for every single request that uses the public key as now the game will reject the official server responses from PONOS.
However, I did still manage to do all of that, but the game refused to upload the save data to the game servers. It does a request to an aws server but it aborts immediately after. I couldn't have changed the url of the server it uploads to to my own server because the url is from a response of another request with a signature that I don't know how to generate.
Another problem is that if you have a request with more than one slash in the same place, serveo.net will respond with a 301 Moved Permanently and redirect to the url with only one slash. But if the original request was a POST request, the method will change to GET and break the request. If it instead used a 308 Permanent Redirect then it would keep the method as POST and it would work. When downloading save data, PONOS accidentally has 2 slashes in the same place. I don't know how to fix this.
I know that this is not a Flask issue because Flask responds correctly with a 308 Permanent Redirect. I think it is a problem with serveo.net.
It's probably possible to do this method but I can't be bothered to do it.
Even though this alternative method is not effective, I spent a lot of time on it so I wanted to include it here.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tbcms-1.0.0.tar.gz
.
File metadata
- Download URL: tbcms-1.0.0.tar.gz
- Upload date:
- Size: 10.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1d8163a5a19350ef2bbe6cc26a88b2f3535417cf921fbc4551c02ab9a2ec26b8 |
|
MD5 | eee3e3800b8cd5b5373be217b3a40c99 |
|
BLAKE2b-256 | e5711e4b94a9f5be7fc80f70f4a1d5f93580e189755dbb00f62f32a792788b0f |
File details
Details for the file tbcms-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: tbcms-1.0.0-py3-none-any.whl
- Upload date:
- Size: 8.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8d09defc2ff1a095374cc63034d265769bb5709ee5d122b190c19b941840636f |
|
MD5 | bc0d72de745f2a33e979caebe7bc56b2 |
|
BLAKE2b-256 | 129b4e0255646731aeb68feb0f4b35da87ac287c6c65f05d82659e9aef539bab |