- Tokens should not be hardcoded into the bot code
- Tokens should never be published
- Tokens should not be pushed into Repositorys
One convenient way to inject your bot token into the application is by using Environment Variables. Environment Variables are Values that are set in the Environment the Bot is running.
Those Values are not defined in the Application and therefore are not visible in the code.
Enviroment Variables in Windows can be set using the Console (CMD) using
SETX [VARIABLE_NAME] [YOUR_BOT_TOKEN]
It can also be set using the Windows GUI
- From the desktop, right click the Computer icon.
- Choose Properties from the context menu.
- Click the Advanced system settings link.
- Click Environment Variables...
- In the 'User Variables for X' click New and enter a Name and your Token as the Value
- Open the '~/.bash_profile' File
- Append the following to it:
export VARIABLE_NAME = {YOUR_BOT_TOKEN}
- Save the file
- Either start a new terminal or run the command above
- Go to Run->Edit Configuratuions...
- Navigate to your Java Run Configuration
- Under Enviroment->Enviroment Variables click the Folder Icon
- Click the Plus Icon to add a new Variable
- Enter a Name and your Token as the Value
- Naviage to your App
- In the Settings Tab under Config Vars, click "Reveal Config Vars"
- Enter a Name and your Token as the Value
- Click the "Add" button
You can access the Enviroment Variables by using System.getEnv()
String BOT_TOKEN = System.getenv("VARIABLE_NAME");
In Spring the @Value annotation allows you to inject the Value into your class
public class Bot extends TelegramLongPollingBot {
public Bot(@Value("${VARIABLE_NAME}") String botToken) {
this.botToken = botToken;
}
}
An easier but not Recommended way of injecting the Bottoken is by utilizing Command Line Arguments when starting the Application
In this case your main Method is responsible for taking in the Token
public static void main(String[] args) {
String botToken = args[0];
}
You now have to call your jar by using
java -jar myBot.jar [BOT_TOKEN]