LMS for Timberline Secondary School's Digital Hackerspace
Although the hackerspace uses several tools, you only need to set up a two of them thanks to docker!
The instructions below will help you get the hackerspace running using docker, and then help you set up a development environment with VS Code.
The instructions assume you are using Ubuntu (or another Debian based linux distro), although it is possible to get it working anywhere you can install docker.
Follow the instructions the for installing Docker CE (community edition, i.e. free edition) using the repository: https://docs.docker.com/install/linux/docker-ce/ubuntu/#install-using-the-repository
By the end, you should be able to run docker's test image:
$ sudo docker run hello-world
sudo apt install docker-compose
Add yourself to the docker group:
sudo usermod -aG docker $USER
- Create a Github account.
- Go to https://github.com/timberline-secondary/hackerspace
- Click the "Fork" button on the top right corner.
- This will allow you to have your own copy of the project on your GitHub account.
- Open the directory where you want to put the code. I like to create a new direcotry for my code projects called Developer:
mkdir ~/Developer
- Move into the parent directory of the project:
cd ~/Developer
- Go to your forked repository in github
- Click "Clone or download" and copy the url, then paste it into the command:
git clone yoururlhere
- This will download the project into ~/Developer/hackerspace/
All the steps required to initially set up the project have been placed into the setup.sh
script. Take a look. If you've used Django before you should recognize some of the steps.
- Open a terminal
- Move into the project directory:
cd ~/Developer/hackerspace
- Run
export DOCKER_HOST=127.0.0.1:8000
- Restart the server with
sudo reboot
- Reconnect to the server
- Move into the project directory:
cd ~/Developer/hackerspace
- Run the setup script to bulid the docker image, and setup your django web app container:
bash setup.sh
- Keep an eye out for errors as it goes through each step.
If everything has worked so far, you should now be able to run your own version of the Hackerspace website:
- make sure you are in the project's root directory:
cd ~/Developer/hackerspace
- Then run it:
docker-compose up
- Keep an eye out for errors as it runs each of the 4 containers (web, redis, db, and celery)
- Once you see this
celery-beat_1 | [2019-09-19 16:11:00,636: INFO/MainProcess] Writing entries...
, press Ctrl+C. - Run
docker-compose up db redis
, and once you getdb_1 | LOG: autovacuum launcher started
, open a new terminal window - Connect to your server again in the new window
- Make sure you are in the project's root directory:
cd ~/Developer/hackerspace
- Run
docker-compose up
- If everything works, then you should see something like this at the end:
web_1 | System check identified no issues (0 silenced).
web_1 | July 21, 2019 - 00:00:45
web_1 | Django version 2.0.13, using settings 'hackerspace_online.settings'
web_1 | Starting development server at http://0.0.0.0:8000/
web_1 | Quit the server with CONTROL-C.
- In your browser go to 127.0.0.1:8000 or if running on a remote server,
serverpublicip:8000
to see if it worked! You can now close your terminals!
10a. If you see a message about Disallowed hosts, reconnect to your server, make sure you are in the project's root directory: cd ~/Developer/hackerspace
, and add your server IP as a string to the ALLOWED_HOSTS
list in /src/hackerspace_online/settings/local.py
- Log in as the superuser you created to see what a teacher/admin sees, or create a new student account.
11a. If you didn't create a sueruser, or setup.sh
never prompted you to, make sure you are in the project's root directory: cd ~/Developer/hackerspace
, then run docker-compose run web python src/manage.py createsuperuser
- If you would like to stop the project, use
Ctrl + C
in the command line, then wait for each of the containers to stop.
(UNTESTED)
- Install Visual Studio Code: https://code.visualstudio.com/docs/setup/setup-overview
- Hit Ctrl + ` (back tick, above the tab key) to open a terminal in VS Code
- Install the following extensions:
- Required: Python (Microsoft)
- Required: Remote - Containers (Microsoft)
- Optional: Django Template (bibhasdn)
- Optional: ESLint: (Dirk Baeumer)
- Optional: GitLens (Eric Amodio)
- Optional: Docker (Microsoft)
- Optional: Git Graph (mhutchie)
- Optional: YAML (Red Hat)
- Restart VS Code so the extension work
- Open the project in VS Code (File > Open Folder)
- You should see a pop up askign if you want to open the project in a container, of not, open the command palette with Ctrl + Shift + P and type: "Remote-Containers" and select: "Reopen Folder in Container"
- VS Code will now spin up the projects conatainers, and your code will open with the django server running.
- You can now edit code with live results
- Move into your cloned directory.
cd ~/Developer/hackerspace
- Add the upstream remote:
git remote add upstream [email protected]:timberline-secondary/hackerspace.git
- Pull in changes from the upstream master:
git fetch upstream
- Merge the changes:
git merge upstream/master
- Create a new branch:
git checkout -b yourbranchname
- Make your changes and them commit:
git commit -am "yourchangeshere"
- Push your branch to your fork of the project:
git push origin yourbranchname
- Go to your fork of the repository.
- Select your recently pushed branch and create a pull request.
- Complete pull request.