RunPal is a web application about running designed for people who wish to keep track of their trainings, create their own running programs, follow these programs and share with others.
What makes this project different from many other similar applications aimed at training logs (e.g. Nike Running, Runtastic, etc) is the possibility to create your own running programs, follow the programs created by others, edit them and use them in a more flexible way.
The web-application is driven on Flask framework with a backend written in Python using several free APIs (e.g. location by IP-address, geolocation data by coordinates, current and historical weather conditions by coordinates, and timestamp) and a built-in database keeping track of users, runs and programs.
Front-end is mostly based on Bootstrap with a bit of personal touch.
The server side is divided into several python files:
application.py
– the main directory used by Flask that outlines the website architecture and the way how the server should respond to different kinds of user requests to different links, as well as correctly handling POST requests and saving informationrunning.db
– the database file maintaining all information about users, their trainings and programshelpers.py
– the file containing definition of various functions called from application.py that does not work with the databaseuserRepository.py
,historyRepository.py
,programHistory.py
– the files containing definition of various functions called from application.py that deal with the database (respectively, the part including user data, run data, and program data)
@app.route("/create-program", methods=["GET", "POST"])
@login_required
def create_program():
"""Create a program"""
# User reached route via GET (as by submitting a form via GET)
if request.method == "GET":
return render_template("create-program.html")
# User reached route via POST (as by submitting a form via POST)
else:
# Add program to database
programRepo.create_program(session["user_id"],
request.form.get("prog-name"),
int(request.form.get("weeks")),
request.form.get("description"),
int(request.form.get("goal")))
return redirect("/programs")
In order to install the project, one should run the command flask run
.
- CS50
- Flask
- Flask-Session
- Requests
- Werkzeug
- Pytz
The project is using several free APIs:
- DarkSky that provides weather conditions on certain time/date at certain location (based on its geo coordinates), used for weather lookup relating to each training and current weather on the user main page
- GeoDB Cities that provides the full list of city names, countries and their respective geo coordinates, is used in logging runs where the user is provided with autocomplete form with potential options based on the first letters typed
- IP Geo Location that provides the geo coordinates based on the IP-address of the user when he/she accesses the relevant page
Some data about the user are calculated automatically by the program:
- Location of the user reflected on the main page (based on IP-address) and respective weather conditions
- Average pace (based on the run duration and distance)
- Calories burnt (based on the data about the training, calories burnt, certain statutory user data and MET coefficients for different kinds of physical activities)
- Metabolic basal rate (based on user's statutory data)
- Age (based on user birthday timestamp and current timestamp)
- Weather conditions for each training as reflected in the history page, based on the chosen location and date/time
- Main picture is taken from personal archives
- Front end is mainly inspired by Bootstrap with certain customization where necessary
- The logo and weather-condition-icons are used from a free source of icons (https://www.flaticon.com)
- The majority of fonts are taken from Google Fonts open source
-
Create account. The system will check whether you choose a valid name and password, then it will redirect the user to the main page. Passwords are securely stored in the encrypted form in a database
-
If the profile already exists, the user will simply log in using his/her credentials
-
The user can view the main page with some information about his current location/weather and some running statistics such as details of last run, next run (if the program is activated), and logged runs in the past
-
The user can add a new run by including the relevant data about it
-
The user can view the run history in descending order (from the latest to the oldest) that includes, among other things, some automatically generated information, such as average pace, calories burnt, temperature on the street during the run
-
The user can create a program and the activate/disactivate it, if he wants to start following it from a specific date, and to see reminders on the man page
Big thank you goes to all organizers of CS50 course who opened the new programming world for me