Find a file
2020-10-08 18:24:04 +01:00
.ddev Add DDEV configuration 2020-09-16 19:41:48 +01:00
.github Update commands in GitHub Actions 2020-10-08 18:24:04 +01:00
.idea Refactor to use a factory class 2020-09-04 13:46:49 +01:00
config Remove Fathom Analytics settings from config 2020-10-07 23:41:50 +01:00
tools/ansible Use npm ci instead of npm install 2020-09-15 22:15:00 +01:00
web Add Send to social media checkbox to posts 2020-10-07 23:17:07 +01:00
.gitignore Add DDEV configuration 2020-09-16 19:41:48 +01:00
.gitmodules Add slides repo as a submodule 2020-08-12 00:51:59 +01:00
ansible.cfg No cows 2020-06-10 21:26:55 +01:00
composer.json Remove Fathom Analytics 2020-09-28 12:39:04 +01:00
composer.lock Remove Fathom Analytics 2020-09-28 12:39:04 +01:00
phpcs.xml.dist Add phpcs.xml.dist 2020-06-30 17:34:31 +01:00
phpstan.neon Fix PHPStan issues 2020-09-04 22:20:30 +01:00
phpunit.xml.dist Use an in-memory sqlite database for testing 2020-05-15 11:53:50 +01:00
README.md Fix link to the Ansistrano role 2020-07-02 23:18:37 +01:00

oliverdavies.uk

Hosting

This site is hosted on a DigitalOcean droplet, which was created using Ansible (see tools/ansible/digitalocean.yml).

Provisioning

To re-provision the server:

# Download the required roles
ansible-galaxy install -r tools/ansible/requirements.yml --force

# Run the provision playbook
ansible-playbook tools/ansible/provision.yml

Deploying

Deployments for this site for managed with Ansible and Ansistrano. Ansible Vault is used to manage sensitive information like database passwords.

Deployments are triggered automatically when changes are pushed to GitHub, and are performed automatically via GitHub Actions on each push to the production branch.

To run a deployment manually, run ansible-playbook tools/ansible/deploy.yml --ask-vault-pass. The Vault password is stored in LastPass.

Generating settings files

Production settings files are generated automatically during a deployment. This is done using the opdavies.drupal_settings_files Ansible role, using variables from tools/ansible/vars/deploy_vars.yml, and performed during Ansistranos After update code build step.

Migrating data into the website

To view the status of all the migrations:

bin/drush.sh migrate:status

To run all the migrations:

bin/drush.sh migrate:import --all

To run all the migrations and update the existing migrated content:

bin/drush.sh migrate:import --all --update

Talks ordering

In order to keep the talks page in the correct order, based on when the next time a talk is being given, the created date for the talk node is automatically updated on each save to match the date of the most future event for that talk.

The view is then sorting the talk nodes based on their created date.