- Clone the repository and access the cloned folder
git clone git@github.com:ahmedfadhil/CoachAIBot.git
cd CoachAiBot
- If you already cloned the repo pull the changes
cd CoachAiBot
git pull
- If you never used the system, remember to install all the dependencies and then run all migrations and seed the database.
Note that now we are using PostgreSQL, so remember to turn ON the server!
bundle install #installs dependencies
bundle exec rake db:drop #drops any old version of the db
bundle exec rake db:create #creates a new db
bundle exec rake db:migrate #runs migrations
bundle exec rake db:seed #seeds the db
- Switch to development branch, only if the last version resides there, otherwise use master branch
git checkout development
- Start ngrok. Ngrok will bind your localhost:3000 to a public address
cd ngrok
./ngrok http 3000
- Now you should see something like this:
ngrok by @inconshreveable (Ctrl+C to quit)
Session Status online
Account Marian Diaconu (Plan: Free)
Version 2.2.8
Region United States (us)
Web Interface http://127.0.0.1:4040
Forwarding http://d9e5ba0e.ngrok.io -> localhost:3000
Forwarding https://d9e5ba0e.ngrok.io -> localhost:3000
Connections ttl opn rt1 rt5 p50 p90
0 0 0.00 0.00 0.00 0.00
- Set Telegram Bot Webhook by making a GET request like this:
curl https://api.telegram.org/bot294560170:AAFaB9cQ-hCzQEfYNr6z30gD2K7FeDZ1gVQ/setWebhook?url=${https_public_address}/webhooks/telegram_vbc43edbf1614a075954dvd4bfab34l1
But replace ${https_public_address}
with your actual https public address.
In the example the https public address is: https://d9e5ba0e.ngrok.io
.
And the bot token is: 294560170:AAFaB9cQ-hCzQEfYNr6z30gD2K7FeDZ1gVQ
.
You can change them if you have to.
This will tell to TelegramAPI to send the user interactions with the bot @CoachAIBot
,
which is associated with the bot token to the https public address generated by ngrok,
which binds the local Rails server.
- If everything went well, you will receive a JSON response like this
{"ok":true,"result":true,"description":"Webhook is set"}
- Lets start crono time-based background job scheduler daemon for Ruby on Rails. We use it for periodically tasks like sending Notifications
bundle exec crono start RAILS_ENV=development
- Now you can start your Rails server.
rails s
- Access
http://localhost:3000/
for the Web Platform - Credentials for LOG IN
email: user@example.com
password: 12345678
-
Search
@CoachAIBot
on Telegram -
Note that the application is developed for Italian users and hence the language developed using a finite state machine automata was intended for Italian users only.
Check the thesis here: CONVERSATIONAL AGENT FOR HEALTH COACHING
If you find this repo useful in your research, please consider citing the following papers:
@inproceedings{fadhil2018effect,
title={The Effect of Emojis when interacting with Conversational Interface Assisted Health Coaching System},
author={Fadhil, Ahmed and Schiavo, Gianluca and Wang, Yunlong and Yilma, Bereket A},
booktitle={Proceedings of the 12th EAI International Conference on Pervasive Computing Technologies for Healthcare},
pages={378--383},
year={2018},
organization={ACM}
}
@article{fadhil2019assistive,
title={Assistive Conversational Agent for Health Coaching: A Validation Study},
author={Fadhil, Ahmed and Wang, Yunlong and Reiterer, Harald},
journal={Methods of information in medicine},
year={2019},
publisher={Georg Thieme Verlag KG}
}
@article{fadhil2019coachai,
title={CoachAI: A Conversational Agent Assisted Health Coaching Platform},
author={Fadhil, Ahmed and Schiavo, Gianluca and Wang, Yunlong},
journal={arXiv preprint arXiv:1904.11961},
year={2019}
}
@article{fadhil2019designing,
title={Designing for Health Chatbots},
author={Fadhil, Ahmed and Schiavo, Gianluca},
journal={arXiv preprint arXiv:1902.09022},
year={2019}
}
@article{fadhilintelligent,
title={Intelligent Conversational Agent Assisted Health Coaching System: The CoachAI Approach},
author={Fadhil, Ahmed}
}
@phdthesis{jumaah2019conversational,
title={Conversational Agent for Health Coaching},
author={JUMAAH, Ahmed},
year={2019},
school={University of Trento}
}
Contributions are welcome. Please consider using the steps below to contribute to the project.
- Fork the project & clone locally.
- Create an upstream remote and sync your local copy before you branch.
- Branch for each separate piece of work.
- Do the work, write good commit messages, and read the CONTRIBUTING file if there is one.
- Push to your origin repository.
- Create a new PR in GitHub.