The public website of Hackers at Cambridge
This website is built using the Swift web framework Kitura. This allows us to build the site fast and reliably and to learn about and contribute to server-side Swift in the process.
For more reasons as to why we chose to do things this way, please read our blog post about it.
We use Docker to make installation quick and painless, make sure you have it installed. This has been tested to work with at least docker 17.03.0-ce, build 60ccb22
and docker-compose version 1.11.2, build dfed245
.
If you are on GNU/Linux, you will also need to install Docker Compose seperately
If you are on Windows, go to Docker settings and ensure the drive you are using is shared.
- Clone this repository:
git clone https://github.com/hackersatcambridge/hac-website.git
- Navigate to the hac-website directory that you've now cloned
- Now run
docker-compose up
This will build the project run the web server at localhost:3000
. It will also watch for changes to the files and rebuild as necessarily. You can stop this process at any time with ^C
(ctrl
+ C
).
When you want to run the project again (and you will, it's great):
- If the Dockerfile has been changed, run
docker-compose build
- run
docker-compose up
If you are on Windows, go to Docker settings and ensure the drive you are using is shared.
We also use use Gulp for hot-reloading and building of the website when we make edits during development, however as inotify doesn't work on shared drives, hot-reloading doesn't work out of the box.
There is an alternative solution available, which essentially requires the following.
Run pip install docker-windows-volume-watcher
, then, after you have done docker-compose up
, open another console window and run docker-volume-watcher
.
Please look at the CONTRIBUTING.md on how to contribute to the project!
You may notice that we aren't using a templating library for rendering HTML. Inspired by the likes of Elm and React, we've written a module HaCTML for making HTML type-safe and Swifty! For an example, have a look at our home page.
We're currently experimenting with the API for HaCTML, and once it's a little more stable we hope to release it as a standalone module.
In order to run unit tests:
docker-compose run web yarn test
This command starts up a docker container that has all the required dependencies, then starts up a development server.
Internally, this command uses the Gulp task runner*. Check out our Gulpfile to see everything that does.
TL;DR
- Builds the Swift files
- Builds the stylesheets
- Starts the server (at
localhost:3000
) - Waits eagerly for you to make changes to any of the files, rebuilds, and reloads the browser (powered by BrowserSync)
*It is worth noting that we are using Gulp v4, which hasn't been officially released. It would be useful to refer to the version 4 documentation.
If you want to access an instance of yarn
or swift
inside the Docker container to do some debugging or modifications, you can simply use docker-compose run
.
docker-compose run web swift <<SWIFT COMMAND>>
docker-compose run web yarn <<YARN COMMAND>>
docker-compose run web yarn gulp <<GULP COMMAND>>
As the container shares source files with your project directory, any source files modified inside the container (e.g. package.json
) will also be modified outside the container (and vice versa).
Documentation on further features can be found in the /Docs
folder.
Now using Vapor Reverted Verison in Heroku.