How to create a new application for @codex_bot platform
This article is about new @codex_bot application development. Throughout this guide we build an application that can provide weather forecast for different periods of time.
For simplicity we use our modern Python SDK. We also provide instructions how to run your own production-ready @codex_bot server.
Before start you need to run @codex_bot Core (read Developer's Guide) or use our @codex_bot
If you are wondering, we have a lot of other useful @codex_bot applications to play with. Check our landing for the further information.
- Python v.3.5.3 can be downloaded by the link (https://www.python.org/downloads/release/python-353/). Just follow installation instructions. You can use newer versions if you need.
- MongoDB (https://www.mongodb.com). Useful hint – you can run Mongo with the Docker. Just follow the instructions in the next section.
- Install a virtual environment for Python
apt-get install virtualenv или pip install virtualenv
- Initialize a virtual environment with
virtualenv venv -p python3
.
You can skip this step if you don't need to run MongoDB in a Docker.
- Create working directory
mkdir mongo
- Run
docker run -v mongo:/data/db -p 27017:27017 -d mongo
The sources of our example application could be found in repository.
- You can get them with
git clone https://github.com/codex-bot/weather weather
- Activate virtual environment
source ../venv/bin/activate
cd weather
- Install necessary packages
pip install -r requirements.txt
cd weather
- Copy sample config to the work config
cp config.py.sample config.py
- Invent a new unique application name and fill corresponding parameter APPLICATION_NAME
- Write to your bot (if you are running @codex_bot Core by yourself) or to the @codex_bot the following command:
/newapp {unique name of app} {your host}
. You will get a token back. Copy this token to corresponding parameter APPLICATION_TOKEN in your config.py
Now, you can run weather application with python main.py
command. If everything is all right, you will get back several debug messages from Core with the prefix Received
In main.py there is an SDK initialization with values from the configuration file.
self.sdk = CodexBot(APPLICATION_NAME, SERVER['host'], SERVER['port'], db_config=DB, token=APPLICATION_TOKEN)
After that, method register_commands tells Core which commands should be redirected to your application (note: this commands might be unique!).
self.sdk.register_commands([
('weather_help', 'help', CommandHelp(self.sdk)),
('weather', 'weather', CommandWeather(self.sdk)),
('cities', 'cities', CommandCities(self.sdk)),
('city', 'city', CommandCity(self.sdk)),
('rain3', 'rain3', CommandWeather(self.sdk)),
('rain10', 'rain10', CommandWeather(self.sdk))
])
Handlers for each command are defined in commands directory. You can find imports in the beginning of the main.py script:
from commands.help import CommandHelp
from commands.cities import CommandCities
from commands.city import CommandCity
from commands.weather import CommandWeather
Our SDK invokes init method with payload parameter. Watch an example in the commangs/cities.py file:
class CommandCities(CommandBase):
async def __call__(self, payload):
self.sdk.log("/cities handler fired with payload {}".format(payload))
await self.sdk.send_text_to_chat(
payload["chat"],
"...message here..."
)
When user inputs /cities
command in the telegram chat with bot, you'll receive a debug message with the payload into your terminal:
logging.py :17 debug() /cities handler fired with payload {'command': 'cities', 'params': '', 'chat': 'RXRI6S0N', 'user': 'VZXTDQ44'}
/city <CITY_ID>
— setting up your location/cities
— view cities list/weather
— get current weather conditions
Ask a question or report a bug on the create issue page.
Know how to improve SDK? Fork it and send a pull request.
We are small team of passionate web-developers consisting of IFMO University students and graduates located in St. Petersburg, Russia. Fell free to give us a feedback on [email protected]