This file contains instructions for updating your Lightning-based Drupal site.
Lightning has a two-pronged update process. Out of the box, it provides a great deal of default configuration for your site, but once it's installed, all that configuration is "owned" by your site and Lightning cannot safely modify it without potentially changing your site's behavior or, in a worst-case scenario, causing data loss.
As it evolves, Lightning's default configuration may change. In certain limited cases, Lightning will attempt to safely update configuration that it depends on (which will usually be locked anyway to prevent you from modifying it). Otherwise, Lightning will leave your configuration alone, respecting the fact that your site owns it. So, to bring your site fully up-to-date with the latest default configuration, you must follow the appropriate set(s) of instructions in the "Manual update steps" section of this file.
If you've installed Lightning using our Composer-based project template, all you need to do is:
cd /path/to/YOUR_PROJECT
composer update
- Run
drush updatedb
or visitupdate.php
to perform automatic database updates. - Perform any necessary manual updates (see below).
Do not use drush pm-update
or drush up
to update Lightning!
Lightning includes specific, vetted, pre-tested versions of modules, and
occasionally patches for those modules (and Drupal core). Drush's updater
totally disregards all of that and may therefore break your site.
To update Lightning safely:
- Download the latest version of Lightning from https://www.drupal.org/project/lightning and extract it.
- Replace your
profiles/lightning
directory with the one included in the fresh copy of Lightning. - Replace your
core
directory with the one included in the fresh copy Lightning. - Visit
update.php
or rundrush updatedb
to perform any necessary database updates. - Perform any necessary manual updates (see below).
These instructions describe how to update your site's configuration to bring it in line with a newer version of Lightning. These changes are never made automatically by Lightning because they have the potential to change the way your site works.
Follow the instructions starting from the version of Lightning you currently use. For example, if you are currently running Beta 1 and are trying to update to Beta 3, you will need to follow the instructions for updating from Beta 1 to Beta 2, then from Beta 2 to Beta 3, in that order.
- If Lightning's content role functionality is available, grant all "creator"
content roles the following permissions, as desired:
- Toolbar: Use the administration toolbar
- Quick Edit: Access in-place editing
- Contextual Links: Use contextual links
This version of Lightning adds the ability to choose an image style, alt text, and other settings each time you embed an image in a WYSIWYG editor, rather that needing to rely on view modes. To enable this functionality:
- As always, visit
update.php
or rundrush updatedb
to perform database updates. - Clear all caches.
- Under Configuration > Content Authoring > Text formats and editors, configure the Rich Text filter format. Under "Filter settings", open the tab labeled "Limit allowed HTML tags and correct faulty HTML".
- In the "Allowed HTML tags" text field, you should see a tag like
<drupal-entity data-*>
. Change it to<drupal-entity data-* alt title>
. - Save the filter format.
- Under Configuration > Content Authoring > Text editor embed buttons, edit the "Media browser" embed button.
- Under "Allowed Entity Embed Display plugins", ensure that the "Media Image" checkbox is checked.
- Save the embed button.
- If you would like to allow authors to choose how embedded media should be displayed, go to Configuration > System > Lightning > Media, ensure that the box labeled "Allow users to choose how to display embedded media" is checked, then submit the form. If the box is not checked, Lightning will automatically choose a preferred display method (the recommended, default behavior).
There are no manual update steps for this version.
There are no manual update steps for this version.
Note:
There is a known issue with Metatag version 8.x-1.1 where you might need to
clear your site's cache after updating. See Metatag 8.x-1.1 Release notes
and this related issue.
As per our Dependency Constraint Policy, Lightning doesn't pin to a specific
version of Metatag, so depending on your your setup, Metatag is likely to be
updated when you update to Lightning 2.1.4. For Composer users, we recommend
pinning to Metatag version 1.0.0. Alternatively, you can be prepared to clear
your site's cache immediately after running update.php
.
There are no manual update steps for this version.
There are no manual update steps for this version.
- To allow fields that use the media browser to filter to only the media types
accepted by the field, do the following:
- Edit the Browser display of the Media view.
- Add the Bundle contextual filter, to the current display only, with
the following settings:
- When the filter value is NOT available, provide a default value:
- Type: Entity Browser Context
- Context key:
target_bundles
- Fallback value:
all
- Multiple values: OR
- When the filter value IS available or a default is provided:
- Specify validation criteria: Yes
- Validator: Media bundle
- Multiple arguments: One or more IDs separated by , or +
- Action to take if filter value does not validate: Display all results for the specified field
- Under the "More" section, "Allow multiple values" should be checked.
- When the filter value is NOT available, provide a default value:
- If the view has the media bundle as an exposed filter (most likely named "Media: Bundle"), edit it and set the "Yield to argument" select box to the name of the argument you just created (which will probably be "Media: Bundle"). If you don't see the "Yield to argument" select box, clear all caches and try again.
- Save the view.
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
If you previously used the lightning.extend.yml file to customize your installation and you have a need to continuously install your application (for example, in an Acquia Cloud Site Factory instance) you will need to convert your extend file into a sub-profile of Lightning. See the Lightning as a base profile documentation for more information.
- Edit the Scheduled update field on any content type that has it. Click *Field settings, set "Allowed number of values" to "Unlimited" and save. Then click Edit, rename the field to "Scheduled updates", and save.
- If you have the Image Browser entity browser available:
- Go to Configuration > Content authoring > Entity browsers and edit the Image Browser entity browser.
- Click Next.
- Empty the "Width of the modal" and "Height of the modal" text fields.
- Click Next, then proceed through the rest of the wizard without changing anything else. Then click Finish to save the entity browser.
- If you have Lightning Workflow installed, add the View moderation states permission to all content reviewer roles.
- If you have Lightning Workflow installed, Go to Structure > Views and edit
the Content view.
- Expand the Advanced section and under Relationships click on 'latest revision'.
- Un-check the "Require this relationship" checkbox and click Apply (all displays).
- Save the view.
- If you have the Landing Page content type installed, there are several manual
update steps (to be performed in order):
- Create a formatted text field on the Landing Page content type. You can re-use the standard node Body field for this purpose.
- Customize the Teaser view mode of the Landing Page content type. Do not enable Panelizer for it. Add the new text field to the display.
- Disable Panelizer for the Default view mode of the Landing Page content type, then add the new text field to the display.
- If you would like search functionality:
- If you would like to use the Drupal database as a search backend, enable the Search API DB module. You don't need to enable this module if you'd rather use Apache Solr (or something else) as a backend.
- Install the Lightning Search component. If you have already enabled Search API DB, Lightning Search will create a search server on top of the database backend, and use it to power the Content search index. Otherwise, you will need to create the server manually, then point the index to it.
- Grant the "Access the Content overview page" and (if available) "Use the Archive transition" permissions to all content type reviewer roles, if there are any.
- Edit the Content view, if you have it, and add the following:
- A required relationship to Content latest revision.
- The Forward revision(s) exist filter. For parity with a clean Lightning installation, label it "Has unpublished edit(s)".
- Install the Diff module.
- If you would like to use Lightning's simple contact form, install the Contact Form feature from the Lightning package. Alternatively, if you'd like to use Contact and Contact Storage's simple form building functionality but not Lightning's default configuration, simply install the Contact and Contact Storage modules.
There are no manual update steps for this version.
Once you have followed the instructions contained in 1.14 to update to 2.0.0, there are no further manual update steps.
There are no manual update steps for this version. However, Lightning 1.14 contains a script which will modify your root project's composer.json file in order to switch your project to the official Drupal.org Packagist and up date you to Lightning 2.0.0.
If you use the tarball to manage your codebase, you can update directly to the 2.x branch with no manual update steps.
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
If you would like to test the new Lightning Preview module and Workspace Preview System in a development environment, enable the Lightning Preview module from module listing page. Note that Lightning Preview and WPS are not yet ready for production environments.
There are no manual update steps for this version.
There are no manual update steps for this version.
- Go to Structure > Views and edit the Media view.
- Edit the Browser display and configure the pager.
- Change "Items to display" to 12 and press Apply.
- Repeat this configuration for the Image Browser display.
- Save the view.
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
After running drush updatedb
or visiting /update.php
:
- Go to Structure > Content types and choose Manage Display for the Landing Page content type.
- Under "Custom Display Settings", make sure the the Full content box is checked.
- Scroll down and ensure the Panelize this view mode and Allow custom overrides of each entity boxes are checked.
- Press Save.
- Click the Full content tab.
- Scroll down and ensure that the Panelize this view mode, Allow custom overrides of each entity, and Allow panelizer default choice boxes are checked.
- Press Save.
- Click the Manage form display tab.
- Move the Panelizer field out the Disabled area. Be sure that "Panelizer" is selected as the widget type, and press Save.
Depending on what customizations you made to Landing Page prior to the update, some, all, or none of these setting might already be enabled.
There are no manual update steps for this version. There are several database
updates. So, as always, be sure to run drush updatedb
or visit /update.php
.
There are no manual update steps for this version.
- Add
<br>
to the Rich Text filter format's list of allowed HTML tags. - Add the following permissions to Media Creator role:
- Access the Media overview page
- Add the following permissions to the Media Manager role:
- Access the Media overview page
- Administer media bundles
- Edit the Media view. Change the Media display, and under Page Settings, set the access permission to "Access the Media overview page".
There are no manual update steps for this version.
There are no manual update steps for this version.
There are no manual update steps for this version.
- Scheduled updates which change several pieces of content at once were broken.
The fix is a change to configuration that is owned by the site, so Lightning
does not attempt to make the change automatically. To implement the fix
manually:
- Go to Configuration > Scheduled Updates Overview > Scheduled Update Types
- Edit the Publish multiple nodes at a certain time update type
- Under "Update Runner Settings", select Default from the "Update Runner" field
- Select every content type listed in the "Content type" field
- Press Save
There are no manual update steps for this version.
- Scheduled updates to content are broken by Lightning's content moderation
functionality. Beta 3 includes a workaround out-of-the-box which is NOT
applied by the update. To implement the fix manually:
- Go to Configuration > Scheduled Updates Overview > Scheduled Update Types
- Edit the Publish single node at certain time update type
- Under "Update Runner Settings", select Latest Revision from the "Update Runner" field
- Under "Advanced Runner Options", select The owner of the update. from the "Run update as" field
- Press Save
- Enable the
view media
permission for theanonymous
andauthenticated
user roles. - Install the Lightning Workflow module.