Skip to content

Latest commit

 

History

History
167 lines (121 loc) · 5.29 KB

README.md

File metadata and controls

167 lines (121 loc) · 5.29 KB

Orchestra Cities

OC Logo

Orchestra Cities is a data and IoT-driven solution that allows cities to collaboratively develop and share Smart City Services using Open APIs and Open Standards. Launched in 2018 by Martel Innovate, Orchestra Cities was initially developed and tested with Antwerp and Helsinki as a solution for the Select4Cities Pre-Commercial Procurement (PCP). Following the PCP, Martel further invested on the platform for the benefit of its customers.

Repository content

This repository hosts the source and build tools for Orchestra Cities' documentation site.

The documentation consists of an introduction, where the most important topics and ideas are briefly explained, and a tutorial, where the user can get some hands-on experience of the most important platform features.

The documentation site source is in the docs folder and it gets fed into MkDocs to build a static site. Nix provides reproducible, sand-boxed and cross-platform development environments.

Development environment

We use Nix to get proper, isolated and reproducible development environments. This is a sort of virtual shell environment on steroids which has in it all the tools you need with the right versions. Plus, it doesn't pollute your machine with libraries that could break your existing programs—everything gets installed in an isolated Nix store directory and made available only in the Nix shell.

First off, you should install Nix and enable the Flakes extension

$ sh <(curl -L https://nixos.org/nix/install) --daemon
$ mkdir -p ~/.config/nix
$ echo 'experimental-features = nix-command flakes' >> ~/.config/nix/nix.conf

Now you can get into our Nix shell and use the tools you need to develop: Bash, git, MkDocs, etc.

$ cd nix
$ nix shell

Once in the Nix shell, any script with a shebang of #!/bin/sh gets executed by the Bash bundled in our Nix shell. For example, save the script below as nix/test.sh and make it executable

#!/bin/sh

sh --version

echo ----------------
which sh
readlink $(which sh)

Running the script inside the Nix shell yields

GNU bash, version 5.2.26(1)-release (aarch64-apple-darwin23.5.0)
...
----------------
/nix/store/8dhzx8i8xp8cl3m33xailx1d48g54m58-dev-shell/bin/sh
/nix/store/fyjay93q3dq2hx3dhx7zhr8kyjnkh9m8-bash-5.2p26/bin/sh

whereas running it outside of the Nix shell on my MacOS M1 with Bash set as a default shell

GNU bash, version 3.2.57(1)-release (arm64-apple-darwin23)
...
----------------
/bin/sh

Editing content

The documentation site source is in the docs folder. Write in plain markdown. Use figures accordingly. Put images and binary resources in docs/rsrc. Respect the naming schema of the files in there to keep it reasonably organised.

You can build the documentation site and live edit it easily with the mkdocs command. After getting into the Nix shell as explained earlier, go back to the repository's root directory and run

$ mkdocs build

This will output the whole static site in the site directory—there's a .gitignore file to keep this directory out of source control. To see what the site looks like, run

$ mkdocs serve

and then browse to http://localhost:8000. If you edit files in the docs directory, your changes should be reflected in the browser.

Cutting a release

Here's how to cut a new release. First off, run the release command from the master branch within your local repository. At the moment, the command implementation blindly assumes the current directory is the repository's root directory, so make sure that is the case as in the sequences of commands below. The release command takes three numbers as input: major, minor and patch numbers of the version you want to release. It then

  1. Updates the first line of docs/index.md with the date of the latest commit in the docs dir.
  2. Commits the change and tags with the specified version.
  3. Pushes the commit and the tag to remote.

For example, the commands below would release version 2.1.4 and tag the commit with v2.1.4.

$ cd nix
$ nix shell
$ cd ..
$ oc release 2 1 4

Next, build the static site tarball from the current git commit, create a GitHub release for the version just tagged (e.g. v2.1.4) and upload the tarball to the GitHub release.

Finally, update the docs-site Nix package to include this release.

Publishing the site

We build a static Web site and package it in a tarball. You should be able to just extract the tarball in a suitable directory on a Web server and serve the plain files in the extracted directory. That's basically what we do to publish the documentation to our Nginx machine serving docs.orchestracities.com.

How to get the tarball containing the static documentation site? Either download it from a GitHub Release or build it yourself with Nix. Even better, if you have a Nix-based Web server setup, you could just import the docs directory of one of our docs-site Nix packages, e.g. docs-site.v1_0_0 for the v1.0.0 release or docs-site.git for the current content of the master branch.