Thank you for contributing to Six Degrees of Wikipedia!
There are three main pieces you'll need to get set up running locally:
- Mock SQLite database of Wikipedia links.
- Backend Python Flask web server.
- Create React App-based frontend website.
There is some larger set up you'll need to run initially as well as some recurring set up every time you want to run the service.
Note: The following instructions have only been tested on macOS.
The first step is to clone the repo and move into the created directory:
$ git clone [email protected]:jwngr/sdow.git
$ cd sdow/
Several global dependencies are required to run the service. Since installation instructions vary and are decently documented for each project, please refer to the links below on how to install them.
- Python - macOS comes with an older
2.x
version of Python, but I recommend usingpyenv
to install the latest2.x
release. pip
- Most recent versions of Python ship withpip
sqlite3
- Can be installed viabrew install sqlite3
.virtualenv
- Helps avoid polluting your global environment.
Once all the required global dependencies above are installed, run the following commands to get everything set up:
$ virtualenv env
$ source env/bin/activate
$ pip install -r requirements.txt
$ python scripts/create_mock_databases.py
$ cp sdow.sqlite sdow/
$ cd website/
$ npm install
$ cd ..
Every time you want to run the service, you need to source your environment, start the backend Flask app, and the frontend website. You can run the backend and frontend apps in different tabs.
To run the backend, open a new tab and run the following commands from the repo root:
$ source env/bin/activate
$ cd sdow/
$ export FLASK_APP=server.py FLASK_DEBUG=1
$ flask run
To run the frontend, open a new tab and run the following commands from the repo root:
$ cd website/
$ npm start
The service should be running at http://localhost:3000.
Here are some highlights of the directory structure and notable source files
.github/
- Contribution instructions as well as issue and pull request templates.config/
- Configuration files for services like NGINX, Gunicorn, and Supervisord.docs/
- Documentation.scripts/
- Scripts to do things like create a new version of the SDOW database, create a mocksdow/
- The Python Flask web server.server.py
- Main entry point which initializes the Flask web server.database.py
- Defines aDatabase
class which simplifies querying the SDOW SQLite database.breadth_first_search.py
- The main search algorithm which finds the shortest path between pages.helpers.py
- Miscellaneous helper functions and classes.
sketch/
- Sketch logo files.sql/
- SQLite table schemas.website/
- The frontend website, based on Create React App..pylintrc
- Default configuration forpylint
.requirements.txt
- Requirements specification for installing project dependencies viapip
.setup.cfg
- Python PEP 8 autoformatting rules.