Jekyll version of the ISMIR Homepage
In most cases, this website can be updated by the following process:
- fork the website
- make one or more edits
- create a pull request
For minor changes, it may be sufficient to edit the website source (of your fork) directly in your web browser. Once your pull request has been approved and merged, the changes will propagate to the live website.
That's it! Simple, right!?
Not all of the content in this website originates from this repository, which is a downstream consumer of three information sources:
- conference-archive: Collection of publication metadata
- mir-datasets: Collection of MIR datasets
- Individual conference websites
If you notice that any publication metadata is incorrect, either here or over at Zenodo, please submit corrections to the conference-archive repository, which maintains the source data for all ISMIR publications.
This is doubly true for missing PDFs. If possible, please provide a URL or upload the PDF in the issue so that we can more easily fix things.
If you would like to add to or update the list of datasets found on this website, please submit corrections to the mir-datasets repository, which maintains the collection provided here.
The websites of past conferences are being migrated to individual repositories in the ISMIR GitHub organization. Each is being served as a separate GitHub pages site, mapped to the corresponding subdomain.
If you find any major issues with these websites, please identify the appropriate repository and create an issue (or ideally a pull request!) there. Please note, however, that these websites are provided primarily for historical purposes, and are in a state of critical-issue only maintenance, e.g. only significant issues may be addressed (and even then...).
This website is written with Jekyll for simplified automatic deployment via GitHub pages. If you are only ever pushing to master, congratulations! this will be rather transparent.
This feedback loop is slow, however, and it is recommended that bigger changes are developed and tested locally. There are a few things to be aware of when doing so:
Make sure you've installed the jekyll
tools. See the instructions here. To serve the website locally, you must be inside the docs
folder, along side the _config.yaml
file:
$ cd ./docs
$ bundle install; bundle exec jekyll serve;
This will not work from the repository root.
The first pass at developing this site, @ejhumphrey couldn't figure out how to properly use relative URLs in Jekyll across (a) the config file, (b) layout files, and (c) markdown in a way that worked for both local development and as a project site in GitHub, prior to taking over the http://ismir.net domain. This issue is detailed more completely here.
Until this is fixed more correctly, a temporary solution has been developed where a single field is specified in the site's _config.yaml
:
base_url: /ismir-home
When developing locally, set this to an empty string (""
) for local development. When pushing to master, this should match the repository name (/ismir-home
).
Once you've built the website and confirmed that it works, you can scp
the site's output to a remote server.
scp -vr docs/_site/* username@your.host.com:~/destination/
This repository is currently configured to build pull requests and commits to master, and in the latter case, redeploy the build output (the static site) to web hosting. While this now makes redeployments easy, configuration was not exactly straightforward.
One can recreate this configuration as follows:
- Create a
.travis.yml
file.- If starting from the one in this repository, delete the
env:globals
and thebefore_install
routine. We'll overwrite these below. - Otherwise, start from the Jekyll template here: https://jekyllrb.com/docs/continuous-integration/travis-ci/
- If starting from the one in this repository, delete the
- Create an SSH key-pair locally with
ssh-keygen
. Here they are calledid_rsa
(private key) andid_rsa.pub
(public key)- The public key must be copied to the host, e.g.
ssh-copy-id -p 22 -i id_rsa.pub username@ip.add.ress.here
- The private key must be modified to eliminate the passphrase via
ssh-keygen -p -f id_rsa -N ''
- The public key must be copied to the host, e.g.
- We can now encrypt environment variables that will be used by
./deploy_production.sh
, a shell script that has been made executable (chmod +x
)- We need to specify two env variables,
DEPLOY_HOST
andDEPLOY_USER
, to access the host. This can be achieved by supplying this call with the right values from the repository root:travis encrypt SOMEVAR="secretvalue" --add
- See the instructions here for complete details: https://docs.travis-ci.com/user/encryption-keys
- Not that these encrypted values provide an extra layer of obfuscation to the location of the server, and are not strictly necessary – future configurations could provide this info as plaintext.
- We need to specify two env variables,
- We must encrypt the private key file so that the Travis-CI build context can copy the built website to the host.
- The private key is encrypted with the following command, issued from the repository root:
travis encrypt-file id_rsa --add
- This will encrypt the file with a
.enc
suffix, and add an additional command tobefore_install
. Add the encrypted file to the repository (NOT THE PRIVATE KEY) and commit both changes. - See the instructions here for complete details: https://docs.travis-ci.com/user/encrypting-files/
- The private key is encrypted with the following command, issued from the repository root:
- The
./deploy_production
script takes a path to the private key to use for securely copying data to the host server. One can similarly use this script locally with appropriately configured SSH keys.- Note that
.travis.yml
is configured to only deploy on commits to master. - The ssh-agent must be kick-started before attempting to copy the website to the host.
- Note that
Here's a shortlist of weird things that have happened in the past that may serve as useful breadcrumbs, should they show up in the future:
-
Only some pages in a collection aren't available: Check the folder permissions on the server. In the past they've been set to 775, rather than 755, and this won't work; rsync will update files, but won't fix these wonky settings.
-
Some links are
html
, other aremypage/
: this is a permalinks issue, look intocollections
, which provide permalinks for free in exchange for a little upfront work. -
Datasets table goes missing: Check upstream, it depends on the mir-datasets repository to serve this correctly.