Stores email-password pairs, gives out Google Play Store tokens.
Using Google Play Store API requires logging in using email and password. If you have a project which works with Google Play Store API you no longer have to make the users use their live accounts or ship your software with your account credentials inside. You can deploy a token dispenser instance and it will provide auth tokens on demand without letting the world know your password.
git clone https://github.com/matlink/token-dispenser
cd token-dispenser
- Edit
src/main/resources/config.properties
mvn install
java -jar target/token-dispenser.jar
- Run it.
docker run --name td -d -t -p 8080:8080 matlink/token-dispenser:latest
- Enter container shell.
docker exec -it td bash
- Edit
passwords/passwords.txt
and add your email-password pairs. One pair - one line.nano
is included in the image. - Exit container shell and restart the container.
docker restart td
config.properties holds token dispenser's configuration.
Two things are configurable:
- web server
- storage
Token dispenser uses spark framework. To configure network address and port on which spark should listen change spark-host
and spark-port
.
There are three storage options supported:
- Plain text Set
storage
toplaintext
to use it.storage-plaintext-path
property is used to store filesystem path to a plain text file with email-password pairs. There is an example here. Securing it is up to you. - MongoDB Set
storage
tomongodb
to use it. Configurable parameters are self-explanatory. - Environment Set
storage
toenv
to use it. Set the environment variablesTOKEN_EMAIL
andTOKEN_PASSWORD
before starting Token dispenser. (Only one email/account is supported.)
Once server is configured, you can get the tokens for regular requests at http://server-address:port/token/email/[email protected] and tokens for checkin requests at http://server-address:port/token-ac2dm/email/[email protected]
gplaycli requires also the GSFid. Token and GSFid can be retrieved using http://server-adress:port/email/gsfid. A random couple (login, password) will be fetched from the provided ones, to load balance over multiple accounts, mitigating account ban possibilities.