I am developing a game and I would like to include some in-app purchases.
I decided to store the purchased items in a database and adding some checks to it. However, there is still one problem: Wouldn't it be possible to simply disassemble the app, exchange the response codes (eg. USER_CANCELED with OK) so, every time I open the dialogue and abort, my game thinks I bought the item?
I did try it on my app so far, however as I lack experience with baksmali, I didn't work for me. In theory, would be (easily) possible? And if yes, what exactly do you have to change in smali and what are countermeasures?
Thanks!
Just an opinion: I don't have much knowledge about android apps, but about the security scope, You should make a decision about prevent cracking of your software or not or how much. The higher security will yield a more troubled application in time and cause your real customers feel bad or will steal their time (because of the decreasing performance). And you will spend your time to secure your application instead of making it a better and more useful. I advice you to read this nice comment too. "if people want your application cracked they will"