winter / wn-redirect-plugin
Advanced redirect plugin for Winter CMS.
Fund package maintenance!
wintercms
Open Collective
Installs: 17 895
Dependents: 0
Suggesters: 0
Security: 0
Stars: 10
Watchers: 2
Forks: 8
Open Issues: 0
Type:winter-plugin
Requires
- php: ^7.4 || ^8.0
- ext-curl: *
- ext-json: *
- composer/installers: ^1.0 || ^2.0
- davaxi/sparkline: ^2.0
- jaybizzle/crawler-detect: ^1.2
- league/csv: ^9.0
- symfony/stopwatch: ^4.0 || ^5.0 || ^6.0
Replaces
- vdlp/oc-redirect-plugin: <=3.1.1
- dev-main
- v4.0.4
- v4.0.3
- v4.0.2
- v4.0.1
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.x-dev
- 2.6.0
- 2.5.13
- 2.5.12
- 2.5.11
- 2.5.10
- 2.5.9
- 2.5.8
- 2.5.7
- 2.5.6
- 2.5.5
- 2.5.4
- 2.5.3
- 2.5.2
- 2.5.1
- 2.5.0
- 2.4.1
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.0
- 2.1.1
- 2.1.0
- 2.0.2
- 2.0.1
- 2.0.0
- 1.10.5
- 1.10.4
- 1.10.3
- 1.10.2
- 1.10.1
- 1.10.0
- 1.9.0
- 1.8.1
- 1.8.0
- 1.7.0
- 1.6.0
- 1.5.0
- 1.4.5
- 1.4.4
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
- dev-fix-save-and-close
- dev-wip/flush-on-save
- dev-develop
This package is auto-updated.
Last update: 2025-01-20 07:50:46 UTC
README
Manage all your HTTP redirects with an easy to use GUI. This is an essential SEO plugin. With this plugin installed you can manage redirects directly from Winter's beautiful interface. Many webmasters and SEO specialists use redirects to optimise their website for search engines.
Installation
This plugin is available for installation via Composer.
composer require winter/wn-redirect-plugin
After installing the plugin you will need to run the migrations and (if you are using a public folder) republish your public directory.
php artisan migrate
Features
- Quick matching algorithm
- A test utility for redirects
- Matching using placeholders (dynamic paths)
- Matching using regular expressions
- Exact path matching
- Importing and exporting redirect rules
- Schedule redirects (e.g. active for 2 months)
- Redirect to external URLs
- Redirect to internal CMS pages
- Redirect to relative or absolute URLs
- Redirect log
- Categorize redirects
- Statistics
- Hits per redirect
- Popular redirects per month (top 10)
- Popular crawlers per month (top 10)
- Number of redirects per month
- And more...
- Multilingual (Need help translating!)
- Supports MySQL, SQLite and Postgres
- HTTP status codes 301, 302, 303, 404, 410
- Caching
History
- 2016: Originally built by Alwin Drenth, a Software Engineer at Van der Let & Partners.
- 2018: The plugin is re-distributed under the vendor name VDLP.Redirect (formerly known as Adrenth.Redirect).
- 2022: The plugin is forked by the Winter CMS maintainers and made available for Winter CMS as Winter.Redirect
The Winter.Redirect plugin is currently maintained by the Winter CMS maintainers and you (the open-source community).
What does this plugin offer?
This plugin adds a 'Redirects' section to the main menu of Winter CMS. This plugin has a unique and fast matching algorithm to match your redirects before your website is being rendered.
Requirements
- Winter CMS 1.1 or higher.
- PHP version 7.4 or higher.
- PHP extensions:
ext-curl
andext-json
.
Supported database platforms
- MySQL
- Postgres
- SQLite
Supported HTTP status codes
HTTP/1.1 301 Moved Permanently
HTTP/1.1 302 Found
HTTP/1.1 303 See Other
HTTP/1.1 404 Not Found
HTTP/1.1 410 Gone
Supported HTTP request methods
GET
POST
HEAD
Performance
All redirects are stored in the database and will be automatically "published" to a file which the internal redirect mechanism uses to determine if a certain request needs to be redirected. This is way faster than querying a database.
This plugin is designed to be fast and should have no negative effect on the performance of your website.
To gain maximum performance with this plugin:
- Enable redirect caching using a "in-memory" caching method (see Caching).
- Maintain your redirects frequently to keep the number of redirects as low as possible.
- Try to use placeholders to keep your number of redirect low (less redirects is better performance).
Caching
If your website has a lot of redirects it is recommended to enable redirect caching. You can enable redirect caching in the settings panel of this plugin.
Only cache drivers which support tagged cache are supported. So driver file
and database
are not supported. For this plugin database and file caching do not increase performance, but can actually have a negative influence on performance. So it is recommended to use an in-memory caching solution like memcached
or redis
.
How caching works
If caching is enabled (and supported) every request which is handled by this plugin will be cached. It will be stored with tag Winter.Redirect
.
When you modify a redirect all redirect cache will be invalidated automatically. It is also possible to manually clear the cache using the 'Clear cache' button in the Backend.
Placeholders
This plugin makes advantage of the symfony/routing
package. So if you need more info on how to make placeholder requirements for your redirection URLs, please go to: https://symfony.com/doc/current/components/routing/introduction.html#usage
Contribution
Please feel free to contribute to this awesome plugin.
Questions? Need help?
If you have any question about how to use this plugin, please don't hesitate to contact us via the Winter CMS Discord. We're happy to help you.