Just A Rather Very Intelligent System, now on Messenger!
Messenger is now used by 900 million people every month. With the launch of Send / Receive API, bots are about to take over.
I created JARVIS with two goals in mind:
- It should have a lot of useful features (both fun and commonly used).
- Anyone can contribute to this project. (As this is module-based, anybody with a decent knowledge of Python can contribute.) One of the prime goals of this project is to lower the entry barrier in the world of open source.
Take a look at the contributing guidelines to see how easy it is to add your code. I'll be waiting for your pull request! 😉
A massive Thank You to all contributors, and congratulations to people who made their first open-source contribution! 🎉
Feel free to add to this list by opening an Issue / Pull Request.
Name | Sample Query | Source (w/ Attribution) |
---|---|---|
anime | death note anime | Hummingbird |
book | anything you want book | Powered by Goodreads |
bye | goodbye | --- |
coin | flip a coin | --- |
currency | usd to eur rate | Fixer.io |
dice | roll a die | --- |
dictionary | define comfort | Words API |
fact | tell me a fact | Offline |
hello | Hi, Jarvis! | --- |
help | What can you do? | --- |
joke | tell me a joke | Offline |
lyrics | paradise lyrics | Powered by musiXmatch |
movie | iron man 2 movie plot | OMDb API |
music | songs by linkin park | Spotify |
news | latest news | Powered by NewsAPI |
quote | random quote | Offline |
request | report a bug request a feature |
--- |
time | time in seattle | TimeZoneDB API |
url | shorten google.com expand http://goo.gl/7aqe |
Google URL Shortener |
video | videos of sia | YouTube |
weather | weather in london | Info provided by OpenWeatherMap |
wiki | wiki html | MediaWiki API |
xkcd | show a random xkcd comic | xkcd |
More sample queries can be found here.
├── modules/ # home for various features
├── modules/src/ # code goes here
├── modules/tests/ # tests go here
├── data/ # home for shared data
├── templates/ # for sending structured messages
├── CONTRIBUTING.md # contributing guidelines
└── jarvis.py # the main bot
JARVIS is at your service here.
- Clone this repo.
- Linux:
a) Debian (Ubuntu, Linux Mint, etc.):sudo apt-get install python-dev libffi-dev libssl-dev
b) Arch Linux:sudo pacman -S python2 libffi openssl
c) Fedora:sudo yum install python-devel libffi-devel openssl-devel
Windows: These should already be pre-installed in your Python bundle.
Mac/OS X:
a) If you install Python using brew, the relevant headers are already installed for you. In other words, you don't need python-devel.
b)brew install pkg-config libffi
export PKG_CONFIG_PATH=/usr/local/Cellar/libffi/3.0.13/lib/pkgconfig/
# May change with libffi version
pip install cffi
c)brew install libtins
pip install -r requirements.txt
python jarvis.py
- Visit the following URLs to see results:
http://localhost:5000/process/?q=<<YOUR_QUERY>>
returns the intent of the query.
http://localhost:5000/search/?q=<<YOUR_QUERY>>
returns the search result of the query.
The "process" endpoint returns what module the system classifies your query into, say a dictionary query or a song search, etc. Visit the following URLs to understand the output format:
http://localhost:5000/process/?q=tell%20me%20a%20joke
http://localhost:5000/process/?q=time%20in%20seattle
http://localhost:5000/process/?q=convert%2025%20usd%20to%20eur
The "search" endpoint returns the actual bot output, that you get when you interact with the bot using that query.
Note that for the search query to work, you have to set your own key (of the module that you want to test) in config.py
If you want a public endpoint, use the below button to deploy on Heroku and fill the relevant API keys that you would like to use:
I started out with rule-based model but it didn't scale well so now I've shifted to Natural Language Processing. Rest assured, I'll strive to keep it as simple as possible so that you, yes you, can contribute!
If you'd like to contribute to the old model, you are welcome to do so as well.
I've created a new branch legacy
for this purpose. I'll be accepting Pull Requests to this branch also. 😄
P.S. If you've come this far, you might as well contribute. Looking for a place to start? Take a look at some of the low-hanging fruits!