There are occasions while you are working on your site that you would like to keep your progress hidden from the world as you prepare to go live or make updates.
This can be done by putting a username and password on the environment, similar to basic authentication on Apache. Visitors will be prompted to authenticate before the site is served.
When a Dev environment is locked, a lock icon will be added to the screenshot of a site on the Your Sites page.
You have the ability to password protect any of the available environments.
- Select the environment (e.g., Dev).
- Select Security.
- Select Locked.
- Provide a username and password.
- Click Lock Environment.
If other members of your team on the site need to access the site, they will also be able to view the authentication credentials when they log in to their accounts.
Now when your page refreshes you will notice that the environment is now "Private". You will also be able to see the credentials needed to access that environment.
You can set a different username and password for each environment. This is important if you only want the Live site publicly viewable, while Dev and Test can be private as you work on your code and content.
To verify that everything is working correctly, visit the URL of the environment that you have made private. You should see an authentication form where you can enter the username and password for that environment to start your session.
While locked, environments will not be cached by the Global CDN.
If you'd like to customize the lock page that displays beneath the authentication form, you can add a
locked.html file in your site's root directory.
When you are ready to make your environment public again, click Security on your Site Dashboard. Next to Environmental Access, click Public. This will clear the credentials you entered and make the web accessible resources available without a basic authentication prompt.
Your site may also be locked and unlocked using Terminus.
To lock a site:
terminus lock:enable <site>:<env> -- user password
To unlock a site:
terminus lock:disable <site>:<env>
If you see an authentication prompt for a different environment (for example, a Dev site authentication prompt on the Test environment), you likely have assets, such as images, loading from a locked environment. Inspect your page source code and search for the locked environment's URL (e.g
dev-yoursite.pantheonsite.io), then replace that with the correct URL for the current environment.
The HTTP Basic Authentication core module (Drupal 8) and Basic HTTP Authentication contrib module (Drupal 7) conflict with Pantheon's Security tool if both are enabled. We recommend using Pantheon's Security tool within the Site Dashboard on target environments, or the module to restrict access, not both.
Sites that have the environment locked on Pantheon in addition to enabling the module will experience 403 errors. You can resolve these errors by unlocking the environment in the Site Dashboard, clearing cache, then disabling the module in Drupal's admin interface. Once you've disabled the module you can safely lock the environment on Pantheon.
Alternatively, you can resolve 403 errors by using Terminus to disable the module:
terminus remote:drush <site>:<env> -- pm-uninstall basic_auth -y
terminus remote:drush <site>:<env> -- pm-disable basic_auth -y