nglasl/silverstripe-misdirection

This module allows both simple and regular expression link redirections based on customisable mappings, either hooking into a page not found or replacing the default automated URL handling.

Installs: 74 107

Dependents: 2

Suggesters: 0

Security: 0

Stars: 4

Watchers: 3

Forks: 18

Open Issues: 6

Type:silverstripe-vendormodule

3.2.0 2025-01-14 05:18 UTC

README

The current release is 3.1.1

This module allows both simple and regular expression link redirections based on customisable mappings, either hooking into a page not found or replacing the default automated URL handling.

Requirement

  • Silverstripe 3.1, 4 or 5

This module does not require the CMS.

Getting Started

Install the module using composer:

composer require nglasl/silverstripe-misdirection dev-master

Then run dev/build.

Select Misdirection through the CMS and create a link mapping.

Overview

Link Mappings

These allow both simple and regular expression link redirections, and can be used for legacy page redirection, vanity URLs (more below), or redirection based on specific URL patterns.

link-mapping

The link mapping with the highest priority (followed by greatest specificity) will be used, and replaces the default automated URL handling out of the box. This default behaviour may be configured to only hook into a page not found:

nglasl\misdirection\MisdirectionRequestFilter:
  enforce_misdirection: false

When there are multiple matches, the link mapping first created will be used. This default behaviour may be configured to prioritise the link mapping most recently created:

nglasl\misdirection\LinkMapping:
  priority: 'DESC'

Vanity URLs and Fallbacks

vanity-URLs-and-fallbacks

Vanity URLs

While it is possible to create these manually (as above), a content author may directly create a link mapping from a page. However, it should be noted that these are instantiated with a low priority of 2, and therefore other link mappings with higher priority will take precedence.

Fallbacks

When a user happens to encounter a page not found, a specified rule may be triggered to prevent displaying this. It is possible for an administrator to configure a global fallback through the site configuration, however a specific page setting will take precedence.

  • Select Settings
  • Select Pages

What's Happening?

The link mappings are processed server side to prevent inefficient and problematic mappings, using a request filter.

When you want to see exactly what is happening behind the scenes for a given URL, the model admin provides a powerful testing interface!

testing

Once a maximum number of requests has been reached, the server will respond with a page not found. The following is the default configuration:

nglasl\misdirection\MisdirectionRequestFilter:
  maximum_requests: 9

testing-maximum-requests

Bypassing Misdirection

It is possible to bypass the request filter completely by appending ?misdirected=1 to the URL. This is fantastic for debugging, however does not apply to the testing interface for obvious reasons.

Default Automated URL Handling

This may be completely replaced, in which case legacy URLs will no longer resolve based on page version history.

nglasl\misdirection\MisdirectionRequestFilter:
  replace_default: true

When a page is moved, the appropriate link mappings are automatically created and maintained. This allows full control over which legacy URLs remain in the system.