coc-token-refresher
v2.0.0
Published
This is a module to generate a fresh API key for Supercell games for your current IP. It supports Clash Royale, Clash of Clans and Brawl Stars.
Downloads
29
Maintainers
Readme
GITHUB: https://github.com/vikasdimaniya/coc-token-refresher Don't forget to give a star to the project on GitHub
What is this?
This is an module to generate a fresh API key for Supercell games for your current IP. It supports Clash Royale, Clash of Clans and Brawl Stars.
Why?
Those API's has a limitation of one API key per IP and a maximum of 10 API keys per user. This is fine if you are using a single IP, but if you are using multiple IPs, you will need to generate a new API key for each IP.
How to use it?
You can use this module by simply adding it to your project and pass game name, your email and password.
const CTR = require('coc-token-refresher')
async function f(){
try{
let response = await CTR.getNewAPI("clashroyale","yourmail","yourpassword")
console.log(response)
}catch(err){
console.log(err)
}
};
f();
Or If you don't want to show your email and password in the code, you can set environment variables for your email and password, they will load automatically. Example:
TERMINAL:
//On Windows
set email="[email protected]"
set password="yourPassword"
//On MAC
export email="[email protected]"
export password="yourPassword"
JavaScript:
const CTR = require('coc-token-refresher')
async function f(){
try{
let response = await CTR.getNewAPI("clashroyale")
//This is enough. If this doesn't work for you, then can use the below code.
//let response = await CTR.getNewAPI("clashroyale",process.env.email,process.env.password)
console.log(response)
}catch(err){
console.log(err)
}
};
f();
It will return a JSON object like this:
{
"name": "Key generated at 8/2/2022 6:19:26 p. m.",
"description": "Key for non-commercial use",
"ipRange": [
"xx.xx.xx.xx"
],
"key": "your_key"
}
Supported game IDs: clashroyale, clashofclans, brawlstars, cr, coc, bs
How it works?
This module login into the game developer portal with your credentials, check if exists a key for your IP and if not, delete the first key and generate a new one for your IP. Otherwise, it will return the existing key. The logic is inspired on TheLearneer/supercell-api. The IP is obtained from ipify.
Optional parameters
whitelist
You can send a whitelist array of API key-names to avoid deleting them. Example:
{
"game": "coc",
"email": "yourmail",
"password": "yourpassword",
"whitelist": [
"important-key-1",
"important-key-2"
]
}
fixedIp
You can set a fixed IP to use instead of the current one. Example:
{
"game": "bs",
"email": "yourmail",
"password": "yourpassword",
"fixedIp": "11.22.33.44"
}
Contributing
Any contributions you make are greatly appreciated. If you have a suggestion that would make this better, please fork the repo and create a Pull Request. You can also simply open an issue.