Jump to content

Using a game's API to give myself all items


67 posts in this topic

Recommended Posts

Updated (edited)

Hello there,

Lately I've been playing around with API's from games & it's pretty fun actually :D
I thought, let's make a small guide/tutorial on an example game so maybe others can do awesome stuff too :D

So I'm sure most of you have ever played or heard about the game Bike Race. Well, this game got me into hacking mobile games & whenever I re-hack this game, I get new features & this was also the game I started experimenting this on.

Requirements for this:

  • Flexible
  • Jailbroken device
  • Some knowledge about http requests? (or just read it for fun..)

Flexible is one of the best tools out there if you're creating tweaks & need to debug something. Flex also has a "Network History" option, which logs all http requests that are being made by the app, in our cause Bike Race.

What a http request does is the following: It sends requests to a server & if the request is valid it'll give you a response.

For example when you clicked on this topic, you have send iOSGods a request to go to this topic, which returns this page as response.


So the main thing in the game Bike Race, are bikes, obviously. Since I've played this game for a long time back in the days, I happen to know that the developers store bikes into your account so when you come back it will restore them. But let's not get ahead of it & first start the game & log some network history...

So when I open up the game, stay on the main screen & look at my network history, I have like 36 requests being made by the game, most of them are stupid & not worth looking into, this is something you'll have to learn to recognize. But let's give you some examples for things that aren't interesting to look at:

  • A request for a image
  • a request to ad providers (may be interesting if you want to disable ads)
  • a request to crashlytics etc etc.
      

Some things that do seem interesting to me:

  • A request being made to a url that actually has the name of the game in it
  • A request being made with the word "player" in it

See the picture below, where the request boxed with red does not seem interesting, and the ones with green do.

UzhTYJkg.jpg


Okay, so now think of what I've said: Whenever I come back to this game, it restores my bikes. To me, this sounds something like player related.
So if you look at the third request in the green box: bikerace-backend.tfgapps.com/players --> the long number above is the given ID.

This is a GET request, which means it's asking the url for data for this specific player. When I click on the arrow ('>'), I get some information about the request:

And some other stuff, but I'm interested in the response. Remember, when you send a request you'd want some kind of response. Sometimes this response is just a Status Code (200 OK, 500 NOT OK etc etc). So when I click "Tab to view" I get this response in json:
 

Spoiler

{
  "player" : {
    "worlds" : {

    },
    "isPaying" : true,
    "id" : "974a6dd2-f0d3-4d55-b66a-a8a860641e51",
    "guestId" : "b0eb68af8-5296-4d66-8bac-03c225c96448",
    "achievements" : [

    ],
    "tournamentsId" : "990bf6e4-ba4d-44a2-87fb-5684948101ae",
    "publicId" : "82cccb24-ff11-4195-81d8-133dda7c4910",
    "bikes" : [

    ],
    "retries" : 3,
    "referralInstallCount" : 0,
    "name" : "Guest_16006"
  }
}

 

I've started a clean account to minimize the json response, as it's very long in my original account.

Okay, so I've got some information about my account, as you can see my bikes is an empty array, because I do not have bikes yet. You can see some Id's for my account, my guest multiplayer name etc etc. So what now? Just change the bikes array right? Nope... this is sadly not how it works, this is the response from our GET request, we can't modify responses. If we could, then any game would get rekt.

All we got now, is player information which we can't directly modify from our request. However, remember: The game restores your progress, so at some point we it must modify our bikes array. So let's earn a bike & check our network history...
dHCkyJF.png

 

Ho-ly-sh!t, this seems interesting. The request method is a PUT, the name already explains what it does, it PUT's something into something... pls don't think about that kids :eyes:. Jokes aside, this seems HUGE! 

We also got something new, a request body. When you send data to a server (POST, PUT, UPDATE/PATCH etc), you enter it in the body of the request.
If I look at my request body, I see this:

 

Spoiler

{
  "bikes" : [
    6
  ]
}

 


Alright, so let's go a little back. Our request method was PUT, and it was send to the url https://bikerace-backend.tfgapps.com/players/974a6dd2-f0d3-4d55-b66a-a8a860641e51/bikes

So it's sending this data, to the player with the ID "974a6dd2-f0d3-4d55-b66a-a8a860641e51" & it's sending it the the players bikes.
Okay, so this is really huge then, as this is a PUT request, we know the url, the format of the data, meaning we can actually modify this.

Now comes the tricky part however, there are so many ways to send requests, you got tools for this, you can do it with curl from your terminal, you can do it with lots of programming languages etc.

I'm going to show you how I tested it: with Python.
Below, you'll see my Python code with comments that explain what what does.

# Importing the requests libary from Python
import requests
# Importing json, so we can print out the response in json.
import json

# Creating a function that takes one argument: The player ID.
def putAllBikesIntoiOSAccount(accountID):
    # The URL we have to send the request to, we got this from the image in the topic!
    url = 'https://bikerace-backend.tfgapps.com/players/' + accountID + '/bikes'
    # The headers, this is the same as MIME Type. Without the headers, it doesn't know what kind of data you're sending.
    headers = {"Content-Type": "application/json"}
    # The body, which will be ALL bikes (75 bikes total)
    body = {"bikes": range(1,75)}
    # The actual request being made. Notice the ".put", as we have to PUT bikes into /bikes.
    # First argument of 'put' is the URL it's being send to. Second the headers & lastly & most important: the body with our biks data.
    request = requests.put(url, headers=headers, json=body)
    # Printing our request, so we can see the result.
    print(request.json())
    return request

# Calling the function with my player ID
putAllBikesIntoiOSAccount("974a6dd2-f0d3-4d55-b66a-a8a860641e51")


Now when I run this python file, this is the response of the request we send:

{'bikes': [6, 1, 2, 3, 4, 5, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75]}


Wow! It seems to work, when I open the game: I got all bikes.

 

Playing around with games like this is much different than modifying their code directly, so that's why prior knowledge about making requests is kinda required.
The process of requests, I can't really explain. You will need some experience yourself, youtube has lot's of tutorials showing you how to retrieve(GET) data from a site, how to send(POST) data, how to update(UPDATE/PATCH) data etc etc.

I know most likely no one will try or understand this, as cheaters on this forum only do code patching, but this might be interesting for a curious person.
Also note that allot of games do have a proper API, where it will be very hard to find a request you can play around with.

Updated by Ted2
  • Like 19
  • Winner 3
  • Thanks 2
  • Haha 1
  • Informative 1
Posted (edited)

Naisuuu

Question is do you need to run the python code everytime you open the game just do it once? 

Updated by Laxus
Posted
1 hour ago, Laxus said:

Naisuuu

Question is do you need to run the python code everytime you open the game just do it once? 

No, it sets the bikes for your account. It's literally using what the game uses to notify the server when you earn a new bike or stuff like that. Nothing local :P

  • Like 2
  • Winner 1
Posted

@Ted2 Good job! You're jumping in an amazing world. :)

 

And btw, this

body = {"bikes": [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75],}

can be replaced with this ;)

body = {"bikes": list(range(1, 75))}

 

  • Like 2
  • Winner 2
  • Haha 1
Posted (edited)
3 hours ago, bR34Kr said:

@Ted2 Good job! You're jumping in an amazing world. :)

 

And btw, this


body = {"bikes": [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75],}

can be replaced with this ;)


body = {"bikes": list(range(1, 75))}

 

Correct, I do have that originally but I thought let’s keep it “simple “ for this “tutorial” :p 

 

Though,  now I think of it, maybe that is keeping it simple. I just happen to know most people here don’t code at all & thought 1,2,3...,75 would make more sense for them than list(range(1,75))

Updated by Ted2
  • Like 2
Posted
17 minutes ago, Ted2 said:

Correct, I do have that originally but I thought let’s keep it “simple “ for this “tutorial” :p 

 

Though,  now I think of it, maybe that is keeping it simple. I just happen to know most people here don’t code at all & thought 1,2,3...,75 would make more sense for them than list(range(1,75))

Thats something i want to learn 😍😍Will try my best . Great stuff Ted2. 

Posted
3 minutes ago, absolut1on said:

Thats something i want to learn 😍😍Will try my best . Great stuff Ted2. 

cheers mate

Posted
Quote

body = {"bikes": [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75],}

Did you seriously write that on your own? Who needs loops anyways? :D

Cool tutorial for beginners! Nothing new though. Wonder why the developers won't take time to write a proper API that's not accessible so easy.

  • Agree 1

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
  • Our picks

    • Cat & Farm: Cute Cat game v0.7.8 [ +1 Cheats ] Currency Max
      Modded/Hacked App: Cat & Farm: Cute Cat game By CSCMOBI VIET NAM TECHNOLOGY JOINT STOCK COMPANY
      Bundle ID: com.cscmobi.catfarm
      App Store Link: https://apps.apple.com/us/app/cat-farm-cute-cat-game/id6723863960?uo=4

        

      🤩 Hack Features

      - Currency Max [ Use Only Currency Disable After Hack ] Because Linked With Exp & Resources


      • 0 replies
    • Cat & Farm: Cute Cat game v0.7.8 [ +1 Jailed ] Currency Max
      Modded/Hacked App: Cat & Farm: Cute Cat game By CSCMOBI VIET NAM TECHNOLOGY JOINT STOCK COMPANY
      Bundle ID: com.cscmobi.catfarm
      App Store Link: https://apps.apple.com/us/app/cat-farm-cute-cat-game/id6723863960?uo=4

       
      🤩 Hack Features

      - Currency Max [ Use Only Currency Disable After Hack ] Because Linked With Exp & Resources


      • 0 replies
    • Slayer Legend Cheats v600.2.6 +5
      Modded/Hacked App: Slayer Legend By GEAR2
      Bundle ID: com.gear2.growslayer
      iTunes Store Link: https://apps.apple.com/us/app/slayer-legend/id1635712706?uo=4


      Hack Features:
      - Multiply Attack
      - Multiply Defense
      - Freeze Currencies


      iOS Hack Download Link: https://iosgods.com/topic/186299-slayer-legend-cheats-v50084-3/
      • 115 replies
    • Toram Online v4.0.65 - [ Custom Move Speed & More ]
      Modded/Hacked App: Toram Online By ASOBIMO,Inc.
      Bundle ID: com.asobimo.toramonline
      iTunes Store Link: https://itunes.apple.com/us/app/toram-online/id988683886?mt=8&uo=4&at=1010lce4
       

      Mod Requirements:
      - Jailbroken iPhone/iPad/iPod Touch.
      - iFile / Filza / iFunBox / iTools or any other file managers for iOS.
      - Cydia Substrate or Substitute.
      - PreferenceLoader (from Cydia or Sileo).


      Hack Features:
      - Custom Move Speed
      - God Mode 
      - Fast Attack Speed
      - Fast Cast Speed
      - Always Critical Chance
      - Never Miss Hit 
      - Mobs/Bosses Can't Avoid & Guard 
      - Quick Draw
      - Armor Break
      - Magic Wall - Stun + Full Map Hack 
      • 2,569 replies
    • Dawn of Ages: Medieval Games v1.7.9 +1 Jailed Cheat [ Auto Win ]
      Modded/Hacked App: Dawn of Ages: Medieval Games By BoomBit, Inc.
      Bundle ID: com.stratospheregames.dawnofages
      iTunes Store Link: https://apps.apple.com/us/app/dawn-of-ages-medieval-games/id6477473268?uo=4


      Hack Features:
      - Auto Win
      • 13 replies
    • Dawn of Ages: Medieval Games v1.7.9 +1 Cheat [ Auto Win ]
      Modded/Hacked App: Dawn of Ages: Medieval Games By BoomBit, Inc.
      Bundle ID: com.stratospheregames.dawnofages
      iTunes Store Link: https://apps.apple.com/us/app/dawn-of-ages-medieval-games/id6477473268?uo=4


      Hack Features:
      - Auto Win
      • 9 replies
    • Cats Mansion - Cute Merge Game v3.6 +5 Jailed Cheats [ Unlimited Energy ]
      Modded/Hacked App: Cats Mansion - Cute Merge Game By Hero Linkage Technology Co., Ltd.
      Bundle ID: com.cute.cat.house
      iTunes Store Link: https://apps.apple.com/us/app/cats-mansion-cute-merge-game/id6470771978?uo=4

       
       

      🤩 Hack Features

      - Always Enough Energy

      VIP
      - Unlimited Energy -> Spend some.
      - Privilege Pass Unlocked
      - All Avatars & Frames Unlocked
      - Unlimited Name Changes
      • 22 replies
    • Cats Mansion - Cute Merge Game v3.6 +5 Cheats [ Unlimited Energy ]
      Modded/Hacked App: Cats Mansion - Cute Merge Game By Hero Linkage Technology Co., Ltd.
      Bundle ID: com.cute.cat.house
      iTunes Store Link: https://apps.apple.com/us/app/cats-mansion-cute-merge-game/id6470771978?uo=4

       
       

      🤩 Hack Features

      - Always Enough Energy

      VIP
      - Unlimited Energy -> Spend some.
      - Privilege Pass Unlocked
      - All Avatars & Frames Unlocked
      - Unlimited Name Changes
      • 13 replies
    • Zombie State: FPS Shooter v2.3.3 +10 Jailed Cheats [ Damage & Defence ]
      Modded/Hacked App: Zombie State: FPS Shooting By MY.GAMES B.V.
      Bundle ID: games.my.zombie.shooter
      iTunes Store Link: https://apps.apple.com/us/app/zombie-state-fps-shooting/id6451382835?uo=4


      Hack Features:
      - Damage Multiplier VIP
      - Defence Multiplier VIP
      - Move Speed Multiplier VIP
      - Unlimited Ammo -> Will not decrease.
      - No Recoil
      - No Spread
      - Increased Fire Rate
      - Kill All Enemies VIP
      - Become Invisible VIP
      - Battle Pass Purchased VIP


      Jailbreak required hack(s): [Mod Menu Hack] Zombie State: FPS Shooter v2.0.1 +10 Cheats [ Damage & Defence ] - Free Jailbroken Cydia Cheats - iOSGods
      Modded Android APK(s): https://iosgods.com/forum/68-android-section/
      For more fun, check out the Club(s): https://iosgods.com/clubs/
      • 87 replies
    • Zombie State: FPS Shooter v2.3.3 +10 Cheats [ Damage & Defence ]
      Modded/Hacked App: Zombie State: FPS Shooting By MY.GAMES B.V.
      Bundle ID: games.my.zombie.shooter
      iTunes Store Link: https://apps.apple.com/us/app/zombie-state-fps-shooting/id6451382835?uo=4


      Hack Features:
      - Damage Multiplier VIP
      - Defence Multiplier VIP
      - Move Speed Multiplier VIP
      - Unlimited Ammo -> Will not decrease.
      - No Recoil
      - No Spread
      - Increased Fire Rate
      - Kill All Enemies VIP
      - Become Invisible VIP
      - Battle Pass Purchased VIP


      Non-Jailbroken & No Jailbreak required hack(s): [Non-Jailbroken Hack] Zombie State: FPS Shooter v2.0.1 +10 Jailed Cheats [ Damage & Defence ] - Free Non-Jailbroken IPA Cheats - iOSGods
      Modded Android APK(s): https://iosgods.com/forum/68-android-section/
      For more fun, check out the Club(s): https://iosgods.com/clubs/
      • 78 replies
    • Loot Heroes v1.5.0 +8 Jailed Cheats [ Unlimited Currencies ]
      Modded/Hacked App: Loot Heroes: Fantasy RPG Games By BoomBit, Inc.
      Bundle ID: com.bbp.lootheroes
      iTunes Store Link: https://apps.apple.com/us/app/loot-heroes-fantasy-rpg-games/id6642699678?uo=4


      Hack Features:
      - Freeze Currencies
      - Unlimited Currencies [ VIP ]
      - God Mode -> Traps still cause damage.
      - One-Hit Kill
      - All Heroes Unlocked
      - Auto Win [ VIP ]
      - Battle Pass Unlocked [ VIP ]


      Jailbreak required hack(s): [Mod Menu Hack] Loot Heroes v1.1.5 +8 Cheats [ Unlimited Currencies + More ] - Free Jailbroken Cydia Cheats - iOSGods
      Modded Android APK(s): https://iosgods.com/forum/68-android-section/
      For more fun, check out the Club(s): https://iosgods.com/clubs/
      • 79 replies
    • Loot Heroes v1.5.0 +8 Cheats [ Unlimited Currencies ]
      Modded/Hacked App: Loot Heroes By BoomBit, Inc.
      Bundle ID: com.bbp.lootheroes
      iTunes Store Link: https://apps.apple.com/us/app/loot-heroes/id6642699678?uo=4


      Hack Features:
      - Freeze Currencies
      - Unlimited Currencies [ VIP ]
      - God Mode -> Traps still cause damage.
      - One-Hit Kill
      - All Heroes Unlocked
      - Auto Win [ VIP ]
      - Battle Pass Unlocked [ VIP ]


      Non-Jailbroken & No Jailbreak required hack(s): https://iosgods.com/forum/79-no-jailbreak-section/
      Modded Android APK(s): https://iosgods.com/forum/68-android-section/
      For more fun, check out the Club(s): https://iosgods.com/clubs/
      • 210 replies
×
  • Create New...

Important Information

We would like to place cookies on your device to help make this website better. The website cannot give you the best user experience without cookies. You can accept or decline our cookies. You may also adjust your cookie settings. Privacy Policy - Guidelines