Skip to content

Latest commit

 

History

History
303 lines (197 loc) · 15.2 KB

CHANGELOG.md

File metadata and controls

303 lines (197 loc) · 15.2 KB

Changelog

2023-07-06.1

Removed branding navigation configuration as it is deprecated and not used any more.

2023-05-24.1

Added better deployment error handling and support for sending Slack messages for failed deployment.

See OpenShift documentation for more information.

2023-05-23.1

Added project specific make commands and documentation how to use node container to build local assets.

See Building assets for more information.

2023-03-28.1

Scheduler cron key is now read from DRUPAL_SCHEDULER_CRON_KEY environment variable when set, and will fall back to $settings['hash_salt'].

The cron key is used by scheduler module to allow scheduler tasks to be triggered via HTTP API (/scheduler/cron/{cron_key}).

Required actions

By default, scheduler is run using Drush (docker/openshift/content-scheduler.sh) and this change should require no actions.

2023-02-03.2

Enabled READ-COMMITTED transaction isolation level MySQL setting by default to improve performance and to minimize locking issues.

See https://www.drupal.org/docs/system-requirements/setting-the-mysql-transaction-isolation-level for more information.

Required actions

  • Run drush helfi:tools:update-platform to update your settings.php file.

2023-02-03.1

Added a GitHub Action to automatically create pull request from dev to main branch when a new commit is added to dev branch.

See City-of-Helsinki/drupal-helfi-platform/blob/main/.github/workflows/auto-release-pr.yml.dist

Required actions

To use this:

  • Run drush helfi:tools:update-platform and rename the newly added auto-release-pr.yml.dist to auto-release-pr.yml

2023-01-18

Twig caches are now compiled on container start. This should considerably speed up the initial request after a new container is spawned.

See docker/openshift/entrypoints/20-deploy.sh.

2022-10-14

PHP 8.1 is now the default PHP version.

Required actions

  1. Run drush helfi:tools:update-platform. See City-of-Helsinki/drupal-tools for instructions if the command does not exist.
  2. Verify and test changes locally
  3. Update DRUPAL_DOCKER_TAG value to 8.1 or 8.1-dev on Azure DevOps (if set).

Optional actions

Update guzzle to newer version to fix deprecation warnings:

  1. Remove drupal/core-recommended package from your composer.json
  2. Check if you have weitzman/drupal-test-traits package installed: composer show weitzman/drupal-test-traits. If it's installed you have to update it to version 2.0: composer require --dev weitzman/drupal-test-traits:^2.0.
  3. Run composer update

2022-05-31.1

Added documentation of how to sync databases between OpenShift environments: documentation/openshift-db-sync.md.

2022-05-19.1

HDBT 3.0

The HDBT theme page layouts and blocks were overhauled and might cause BC breaks. See changes: https://github.com/City-of-Helsinki/drupal-hdbt/releases/tag/3.0.0

Required actions

  1. Make sure your Drupal instance is up and running on latest dev/main branch
  2. Update the HDBT and necessary modules by running: composer require -W drupal/hdbt:^3.0; composer update -W drupal/helfi_platform_config drupal/helfi_tpr drupal/hdbt_admin.
  3. Run updates and export configuration. make drush-updb drush-cr drush-cex
  4. Check that exported configuration is correct and commit the configuration changes to your repository.

2022-03-04.1

Changed druidfi/db:mysql5.7-drupal docker image to druidfi/mariadb:10.5-drupal

This change was necessary since the base mysql image used to build druidfi/db:mysql5.7-drupal does not support Apple's M1 chip (arm64).

Required actions

  • Run drush helfi:tools:update-platform or update your docker-compose.yml manually.

2021-01-07.1

Introducing drupal/helfi_drupal_tools package

The Drupal tools aims to provide a way to automatically sync updates from drupal-helfi-platform.

Required actions

2021-11-25.2

Database sync from dev/testing to local

Added a support for database syncing from dev/testing environment to local.

Required actions

  • Copy contents from drush/ folder to your project's repository
  • Copy tools/make/project/install.mk and .gitignore files to your project's repository
  • Add OC_PROJECT_NAME= environment variable to your .env file. The value should be your project's name in OpenShift
  • Restart containers (make stop && make up)

Run make fresh to start the database sync.

Optional actions

You can use stage_file_proxy module to serve files directly from your testing/dev environment without having to sync them to your local environment.

  • Copy settings.php and add STAGE_FILE_PROXY_ORIGIN and STAGE_FILE_PROXY_ORIGIN_DIR environment variables to your .env file
  • Install and enable stage_file_proxy module (composer install drupal/stage_file_proxy, drush en stage_file_proxy)

If you store files in azure blob storage then STAGE_FILE_PROXY_ORIGIN value should be something like https://{storage-accountname}.core.windows.net and STAGE_FILE_PROXY_ORIGIN_DIR should be your container's name, for example dev.

Otherwise STAGE_FILE_PROXY_ORIGIN should be an URL to your instance (https://nginx-{project}-{env}.agw.arodevtest.hel.fi) and STAGE_FILE_PROXY_ORIGIN_DIR is sites/default/files.

2021-11-25.1

Pre-built drupal image that supports the new Apple M1 chip

Required actions

  • Remove docker/local folder (rm -r docker/local)
  • Update value for DRUPAL_IMAGE in your .env file: DRUPAL_IMAGE=ghcr.io/city-of-helsinki/drupal-web:8.0
  • Copy docker-compose.yml to your project's repository

2021-10-06.1

Tunnistamo 2.0

Tunnistamo module has a major release to support openid_connect:2.0.

Required actions

  • Run composer require "drupal/helfi_tunnistamo:^2.0" -W in your project's root
  • Run database updates: drush updb -y
  • Delete old openid_connect clients: rm conf/cmi/openid_connect.settings.facebook.yml conf/cmi/openid_connect.settings.generic.yml conf/cmi/openid_connect.settings.github.yml conf/cmi/openid_connect.settings.google.yml conf/cmi/openid_connect.settings.linkedin.yml conf/cmi/openid_connect.settings.tunnistamo.yml
  • Re-create tunnistamo client from /admin/config/people/openid-connect
  • Update any settings.php overrides (settings key was changed to client), for example: $config['openid_connect.settings.tunnistamo']['settings']['is_production'] should now be $config['openid_connect.client.tunnistamo']['settings']['is_production'].

2021-09-16.1

HELfi Platform Config 2.0

Update/install instructions for:

  • drupal-helfi-platform-config 2.0.0

Required actions

  1. Install the site with your current configuration by running either make new or make fresh.
  2. When the site is up and running, run composer require drupal/helfi_platform_config:^2.0 --with-all-dependencies to retrieve the new version of HELfi Platform config.
  3. Run updates and export the configurations by running make drush-updb drush-cr drush-cex.
  4. Go through configuration changes from /conf/cmi/ and revert/modify any changes what will override your customised configurations.
  5. Commit the changes to your repository.

2021-09-14.1

Run deploy tasks only once per deploy

At the moment the deploy script is run every time a container replica is started. This can lead to a race condition when multiple containers are running deploy script at the same time, corrupting the entire configuration stack.

Required actions

Replace your existing docker/openshift/entrypoints/20-deploy.sh with the updated one from this repository.

2021-08-12.1

Easy breadcrumb 2.0

Update/install instructions for:

  • drupal-helfi-platform-config 1.3.0
  1. Update the HELfi platform config module by running: composer require drupal/helfi_platform_config:1.3.0 --with-all-dependencies.
  2. Update your current Easy breadcrumb configuration file by copying the default settings file from /public/modules/contrib/helfi_platform_config/features/helfi_base_config/config/install/easy_breadcrumb.settings.yml to /conf/cmi. Do not forget to change any previously made changes to what was made to the file.
  3. Commit the configurations changes to your repository.

2021-06-09.1

OpenShift deploy script fix

Deploy script was previously meant to be run after nginx process was started, causing it to never run. This should be fixed now.

Required actions

You can either remove entire docker/openshift folder and replace it with docker/openshift folder from this repository or:

  1. Remove docker/openshift/entrypoints/90-deploy.sh file from your repository and replace it with docker/openshift/entrypoints/20-deploy.sh from platform's repository.
  2. Modify docker/openshift/Dockerfile file and change lines containing 90-deploy.sh to 20-deploy.sh.

2021-06-08.1

Cron support on OpenShift

Added support to run crons on OpenShift environment. See docker/openshift/README.md for more information.

Required actions

  • Copy contents from docker/openshift folder to your repository's docker/openshift folder.
  • This change requires actions from IBM. Use helsinkisolutionoffice JIRA to create a ticket labeled Drupal cron support: {project name} and assign it to your project's EPIC.

2021-06-07.2

Remote video paragraph

Update/install instructions for:

  • drupal-hdbt 1.3.5
  • drupal-helfi-platform-config 1.2.6
  1. composer update // Update dependencies.
  2. make shell // Log in to shell
  3. drush features:import helfi_content -y // Revert the Helfi content configuration feature.
  4. Exit shell.
  5. make drush-cr drush-cex // Rebuild caches, Export configurations.
  6. Check that the configuration changes hasn’t overridden any of your custom modifications.
  7. Commit the configurations changes to your repository.

2021-06-07.1

Branding navigation

Update/install instructions for:

  • drupal-hdbt 1.3.4
  • drupal-helfi-platform-config 1.2.5
  1. composer update // Update dependencies.
  2. make shell // Log in to shell
  3. drush features:import helfi_base_config -y // Revert the Helfi base configuration feature.
  4. Exit shell.
  5. make drush-updb drush-cr drush-cex // Run updates; Update theme blocks. ( hdbt_content 9001 ), Rebuild caches, Export configurations.
  6. Check that the configuration changes hasn't overridden any of your custom modifications.
  7. Commit the configurations changes to your repository.

2021-06-03.1

Stonehenge update

Updated Stonehenge to 3.x version. IMPORTANT: This contains backward incompatible changes and requires manual actions.

Stonehenge 3.x changed the default domain from *.docker.sh to *.docker.so.

To update any existing project to use Stonehenge 3.x:

  • Go to your stonehenge installation folder and run git pull && git checkout 3.x
  • Run make down && make up (in stonehenge's installation folder)
  • Update your project's .env and README.md with new *.docker.so domain
  • Restart project's docker containers (make stop && make up)

2021-06-02.1

New Docker base images

Added new Docker base images. NOTE: This change needs to be coordinated with IBM. Use helsinkisolutionoffice JIRA to create a ticket where you coordinate this change. For example: https://helsinkisolutionoffice.atlassian.net/browse/PLATTA-749

Available PHP versions: 8.0 and 7.4 (8.0 is used by default).

Required actions

  • Copy contents from platform's docker/ directory to your repository's docker/ folder
  • Update your repository's .env file to use correct image (commit):
-DRUPAL_IMAGE=druidfi/drupal:7.4-web
+DRUPAL_IMAGE=druidfi/drupal:8.0-web
  • Run docker-compose build and make stop && make start inside your project to update your local environment to use PHP 8.0.
  • Update your repository's .github/workflows/test.yml to run tests with PHP 8 (commit):
-image: ghcr.io/city-of-helsinki/drupal-php-docker:7.4
+image: ghcr.io/city-of-helsinki/drupal-php-docker:8.0

PHP version can be changed by modifying docker/openshift/Dockerfile and docker/local/Dockerfile and changing the version tag from 8.0 to 7.4 (not recommended).

2021-05-28.1

Admin toolbar

Added Admin toolbar (admin_toolbar) as a dependency for the helfi-platform-config.

Required actions

  • In case of an error "Unable to install HELfi Base config module since it requires the Admin Toolbar Extra Tools, Configuration replace, Field group modules."
    • Enable the modules manually, export the configuration and commit the changes to your repository. drush en -y admin_toolbar_tools config_replace field_group && drush cex -y

2021-05-25.1

Converted hdbt and hdbt_admin to be drupal-themess instead of drupal-custom-themess, meaning that they will be installed inside themes/contrib folder from now on.

You can update existing themes with composer update drupal/hdbt and composer update drupal/hdbt_admin and then run drush cr.

Required actions

  • Update paths on conf/cmi/select2_icon.settings.yml to point to /themes/contrib/hdbt/ instead of the current /themes/custom/hdbt/.

2021-05-21.1

Converted all helfi_ to be drupal-modules instead of drupal-custom-modules, meaning that they will be installed inside modules/contrib folder from now on.

You can update existing modules with composer update drupal/helfi_* and then run drush cr.

Required actions

2021-05-12.1

Excluded all helfi_ prefixed modules from phpunit tests (see phpunit.xml.dist) by default. Use phpunit.platform.xml (vendor/bin/phpunit -c phpunit.platform.xml) to run ALL tests, including custom helfi modules.