fork / craft-here
Use the SEO plugin redirects to write nginx and apache redirect map config files (perfect for headless Craft CMS Setups)
Installs: 368
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 7
Forks: 1
Open Issues: 0
Type:craft-plugin
Requires
- php: ^8.2
- craftcms/cms: ^5.0
- ether/seo: ^5.0
Requires (Dev)
- craftcms/ecs: dev-main
- craftcms/phpstan: dev-main
- craftcms/rector: dev-main
- friendsofphp/php-cs-fixer: ^3.64.0
- phpstan/phpstan: ^1.12.6
This package is auto-updated.
Last update: 2025-03-28 16:23:18 UTC
README

Table of contents
Features
- Manage custom redirects directly within the server configuration (for Nginx and Apache)
- Perfectly suited for headless Craft CMS Setups
- Use the redirects features and UI of the Craft SEO Plugin
Requirements
- Craft CMS 5
- Craft SEO Plugin
Setup
1. Install
Install the package
cd /path/to/project
composer require fork/craft-here
2. Configuration file
- Copy the example
config.php
to your Craft config directory and rename it toredirects.php
- Specify the server type (and a reload command if you use nginx). Here's an example:
<?php return [ // Global settings '*' => [ 'serverType' => 'nginx' // or 'apache' ], // Dev environment settings 'dev' => [ //'redirectsReloadCommand' => 'my-command', ], // Staging environment settings 'staging' => [ ], // Production environment settings 'production' => [ //'redirectsReloadCommand' => 'sudo /etc/init.d/nginx reload', ], ];
In your server configuration include the redirect map files (which will be created after plugin has been installed):
# NGINX EXAMPLE: # see https://serverfault.com/a/890715/487169 for why we use "[.]" instead of a regular period "." include /var/www/html/redirects/my.domain.com/redirects-301[.]map; include /var/www/html/redirects/my.domain.com/redirects-302[.]map; # 301 MOVED PERMANENTLY if ($redirect_moved = false) { set $redirect_moved ""; } if ($redirect_moved != "") { rewrite ^(.*)$ $redirect_moved permanent; } # 302 FOUND (aka MOVED TEMPORARILY) if ($redirect_found = false) { set $redirect_found ""; } if ($redirect_found != "") { rewrite ^(.*)$ $redirect_found redirect; }
# APACHE EXAMPLE: RewriteEngine On RewriteMap redirects-301 txt:/var/www/html/redirects/my.domain.com/redirects-301.map RewriteMap redirects-302 txt:/var/www/html/redirects/my.domain.com/redirects-302.map RewriteCond ${redirects-301:%{REQUEST_URI}} ^.+$ RewriteRule .* https://${redirects-301:%{HTTP_HOST}%{REQUEST_URI}} [redirect=permanent,last] RewriteCond ${redirects-302:%{REQUEST_URI}} ^.+$ RewriteRule .* https://${redirects-302:%{HTTP_HOST}%{REQUEST_URI}} [redirect=temp,last]
Usage
Once the plugin has been installed it will create all necessary redirect map files which need to be included into the server config. After that just use the SEO Plugin UI to manage your redirects.
Roadmap
- Settings maybe (instead of config file)

Brought to you by Fork Unstable Media GmbH