From ed1647b782c6e175fcf3607c10406793418efdb2 Mon Sep 17 00:00:00 2001 From: Leo Friedrichs Date: Thu, 21 Jul 2016 11:35:54 +0200 Subject: [PATCH] Initial commit --- .../Adminhtml/System/Config/Fieldset/Hint.php | 92 +++++ .../Block/System/Config/Backend/Download.php | 47 +++ .../Block/System/Config/Backend/Download1.php | 47 +++ .../Backend/Downloadquerystringfile.php | 47 +++ .../Optimiseweb/Redirects/Helper/Data.php | 14 + .../Redirects/Model/Redirector.php | 247 ++++++++++++ .../Optimiseweb/Redirects/doc/Readme.html | 120 ++++++ .../Optimiseweb/Redirects/etc/adminhtml.xml | 68 ++++ .../Optimiseweb/Redirects/etc/config.xml | 111 ++++++ .../Optimiseweb/Redirects/etc/system.xml | 355 ++++++++++++++++++ .../system/config/fieldset/hint.phtml | 33 ++ app/etc/modules/Optimiseweb_Redirects.xml | 17 + app/locale/en_US/Optimiseweb_Redirects.csv | 0 composer.json | 14 + modman | 14 + 15 files changed, 1226 insertions(+) create mode 100644 app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php create mode 100644 app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php create mode 100644 app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php create mode 100644 app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php create mode 100644 app/code/community/Optimiseweb/Redirects/Helper/Data.php create mode 100644 app/code/community/Optimiseweb/Redirects/Model/Redirector.php create mode 100644 app/code/community/Optimiseweb/Redirects/doc/Readme.html create mode 100644 app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml create mode 100644 app/code/community/Optimiseweb/Redirects/etc/config.xml create mode 100644 app/code/community/Optimiseweb/Redirects/etc/system.xml create mode 100644 app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml create mode 100644 app/etc/modules/Optimiseweb_Redirects.xml create mode 100644 app/locale/en_US/Optimiseweb_Redirects.csv create mode 100644 composer.json create mode 100644 modman diff --git a/app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php b/app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php new file mode 100644 index 0000000..ffe7659 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php @@ -0,0 +1,92 @@ +toHtml(); + } + + public function getModuleName() + { + return 'Mass 301 Redirects'; + } + + public function getModuleVersion() + { + return (string) Mage::getConfig()->getNode('modules/Optimiseweb_Redirects/version'); + } + + public function getOptimisewebRedirectsVersion() + { + return $this->getModuleVersion(); + } + + public function getCheckExtensions() + { + return array(); + } + + public function getOptimiseWebUrl() + { + $url = 'https://optimiseweb.co.uk?'; + $url .= 'utm_source=Magento_Extension&utm_medium=Extension_Settings&utm_campaign=Optimiseweb_Redirects'; + return $url; + } + + public function getOptimiseWebEmailLink() + { + $email = 'sid@optimiseweb.co.uk'; + $emailLink = 'mailto:' . $email; + return $emailLink; + } + + public function getKathirVelUrl() + { + $url = 'http://www.kathirvel.com?'; + $url .= 'utm_source=Magento_Extension&utm_medium=Extension_Settings&utm_campaign=Optimiseweb_Redirects'; + return $url; + } + + public function getHelpDeskUrl() + { + $url = 'https://optimiseweb.co.uk/magento-extension-support/?'; + $url .= $this->getPxParams(); + return $url; + } + + public function getPxUrl() + { + $url = 'https://optimiseweb.co.uk/magento-connect/assets/logo/optimiseweb.jpg'; + return $url; + } + + public function getPxParams() + { + $v = $this->getModuleVersion(); + $ext = 'Optimiseweb_Redirects_' . $v; + $modulesArray = (array) Mage::getConfig()->getNode('modules')->children(); + $aux = (array_key_exists('Enterprise_Enterprise', $modulesArray)) ? 'EE' : 'CE'; + $mageVersion = Mage::getVersion(); + $mage = 'Magento_' . $aux . '_' . $mageVersion; + return 'extension=' . $ext . '&magento=' . $mage; + } + +} diff --git a/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php new file mode 100644 index 0000000..076ee33 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php @@ -0,0 +1,47 @@ +getRequest()->getParam('store'); + $website = Mage::app()->getRequest()->getParam('website'); + if ($store) { + $storeData = Mage::getModel('core/store')->getCollection()->addFieldToFilter('code', $store)->getFirstItem(); + $storeId = $storeData->getStoreId(); + $fileName = Mage::getStoreConfig('optimisewebredirects/general/upload', $storeId); + } elseif ($website) { + $websiteData = Mage::getModel('core/website')->getCollection()->addFieldToFilter('code', $website)->getFirstItem(); + $websiteId = $websiteData->getWebsiteId(); + $fileName = Mage::app()->getWebsite($websiteId)->getConfig('optimisewebredirects/general/upload'); + } else { + $fileName = Mage::getStoreConfig('optimisewebredirects/general/upload'); + } + + $this->setElement($element); + + if ($fileName) { + $url = Mage::getBaseUrl(Mage_Core_Model_Store::URL_TYPE_MEDIA) . 'optimiseweb/redirects/' . $fileName; + $html = "Download"; + } else { + $html = "No CSV file provided."; + } + return $html; + } + +} diff --git a/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php new file mode 100644 index 0000000..0b182eb --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php @@ -0,0 +1,47 @@ +getRequest()->getParam('store'); + $website = Mage::app()->getRequest()->getParam('website'); + if ($store) { + $storeData = Mage::getModel('core/store')->getCollection()->addFieldToFilter('code', $store)->getFirstItem(); + $storeId = $storeData->getStoreId(); + $fileName = Mage::getStoreConfig('optimisewebredirects/redirects1/upload', $storeId); + } elseif ($website) { + $websiteData = Mage::getModel('core/website')->getCollection()->addFieldToFilter('code', $website)->getFirstItem(); + $websiteId = $websiteData->getWebsiteId(); + $fileName = Mage::app()->getWebsite($websiteId)->getConfig('optimisewebredirects/redirects1/upload'); + } else { + $fileName = Mage::getStoreConfig('optimisewebredirects/redirects1/upload'); + } + + $this->setElement($element); + + if ($fileName) { + $url = Mage::getBaseUrl(Mage_Core_Model_Store::URL_TYPE_MEDIA) . 'optimiseweb/redirects/' . $fileName; + $html = "Download"; + } else { + $html = "No CSV file provided."; + } + return $html; + } + +} diff --git a/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php new file mode 100644 index 0000000..4e3f602 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php @@ -0,0 +1,47 @@ +getRequest()->getParam('store'); + $website = Mage::app()->getRequest()->getParam('website'); + if ($store) { + $storeData = Mage::getModel('core/store')->getCollection()->addFieldToFilter('code', $store)->getFirstItem(); + $storeId = $storeData->getStoreId(); + $fileName = Mage::getStoreConfig('optimisewebredirects/querystring/upload', $storeId); + } elseif ($website) { + $websiteData = Mage::getModel('core/website')->getCollection()->addFieldToFilter('code', $website)->getFirstItem(); + $websiteId = $websiteData->getWebsiteId(); + $fileName = Mage::app()->getWebsite($websiteId)->getConfig('optimisewebredirects/querystring/upload'); + } else { + $fileName = Mage::getStoreConfig('optimisewebredirects/querystring/upload'); + } + + $this->setElement($element); + + if ($fileName) { + $url = Mage::getBaseUrl(Mage_Core_Model_Store::URL_TYPE_MEDIA) . 'optimiseweb/redirects/' . $fileName; + $html = "Download"; + } else { + $html = "No CSV file provided."; + } + return $html; + } + +} diff --git a/app/code/community/Optimiseweb/Redirects/Helper/Data.php b/app/code/community/Optimiseweb/Redirects/Helper/Data.php new file mode 100644 index 0000000..8b2322d --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/Helper/Data.php @@ -0,0 +1,14 @@ +getEvent()->getControllerAction()->getRequest(); + + $actionName = $request->getActionName(); + + $disabledProductCheck = $this->disabledProductCheck($request); + $notvisibleProductCheck = $this->notvisibleProductCheck($request); + $disabledCategoryCheck = $this->disabledCategoryCheck($request); + + $requestUrl = rtrim($request->getScheme() . '://' . $request->getHttpHost() . $request->getRequestUri(), '/'); + if ($disabledProductCheck) { + //$requestUrl = rtrim($request->getScheme() . '://' . $request->getHttpHost() . '/' . $disabledProductCheck, '/'); + $requestUrl = rtrim(Mage::getUrl() . $disabledProductCheck, '/'); + } + if ($notvisibleProductCheck) { + //$requestUrl = rtrim($request->getScheme() . '://' . $request->getHttpHost() . '/' . $disabledProductCheck, '/'); + $requestUrl = rtrim(Mage::getUrl() . $notvisibleProductCheck, '/'); + } + if ($disabledCategoryCheck) { + //$requestUrl = rtrim($request->getScheme() . '://' . $request->getHttpHost() . '/' . $disabledCategoryCheck, '/'); + $requestUrl = rtrim(Mage::getUrl() . $disabledCategoryCheck, '/'); + } + if (($actionName == 'noRoute') OR $disabledProductCheck OR $notvisibleProductCheck OR $disabledCategoryCheck) { + Mage::dispatchEvent('optimiseweb_redirects_before_legacy', array('request_url' => &$requestUrl)); + $this->doRedirectsLegacy($requestUrl); + Mage::dispatchEvent('optimiseweb_redirects_before_v1', array('request_url' => &$requestUrl)); + $this->doRedirects1($requestUrl); + Mage::dispatchEvent('optimiseweb_redirects_before_query_strings', array('request_url' => &$requestUrl)); + $this->doQueryStringRedirects($requestUrl); + Mage::dispatchEvent('optimiseweb_redirects_before_catalogue_search', array('request_url' => &$requestUrl)); + $this->doRedirectsToCatalogueSearch($requestUrl); + Mage::dispatchEvent('optimiseweb_redirects_before_exiting', array('request_url' => &$requestUrl)); + } + return; + } + + protected function disabledProductCheck($request) + { + if ($request->getActionName() !== 'noRoute') { + if ((bool) Mage::getStoreConfig('optimisewebredirects/disabled_products/enabled')) { + if (($request->getModuleName() == 'catalog') AND ( $request->getControllerName() == 'product') AND ( $request->getActionName() == 'view')) { + if ($product = Mage::getModel('catalog/product')->load(Mage::app()->getRequest()->getParam('id'))) { + if ($product->getStatus() == 2) { + return $product->getUrlPath(); + } + } + } + } + } + return FALSE; + } + + protected function notvisibleProductCheck($request) + { + if ($request->getActionName() !== 'noRoute') { + if ((bool) Mage::getStoreConfig('optimisewebredirects/notvisible_products/enabled')) { + if (($request->getModuleName() == 'catalog') AND ( $request->getControllerName() == 'product') AND ( $request->getActionName() == 'view')) { + if ($product = Mage::getModel('catalog/product')->load(Mage::app()->getRequest()->getParam('id'))) { + if ($product->getVisibility() == 1) { + return $product->getUrlPath(); + } + } + } + } + } + return FALSE; + } + + protected function disabledCategoryCheck($request) + { + if ($request->getActionName() !== 'noRoute') { + if ((bool) Mage::getStoreConfig('optimisewebredirects/disabled_products/enabled')) { + if (($request->getModuleName() == 'catalog') AND ( $request->getControllerName() == 'category') AND ( $request->getActionName() == 'view')) { + if ($category = Mage::getModel('catalog/category')->load(Mage::app()->getRequest()->getParam('id'))) { + if ($category->getIsActive() == 0) { + return $category->getUrlPath(); + } + } + } + } + } + return FALSE; + } + + protected function doRedirectsLegacy($requestUrl) + { + if (Mage::getStoreConfig('optimisewebredirects/general/upload') AND file_exists(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/general/upload'))) { + + $redirectLines = file(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/general/upload')); + + foreach ($redirectLines AS $redirectLine) { + + $sourceDestination = explode(';', $redirectLine); + + if (count($sourceDestination) == 2) { + $sourceUrl = rtrim(trim($sourceDestination[0]), '/'); + $destinationUrl = trim($sourceDestination[1]); + + if ($sourceUrl == $requestUrl) { + $response = Mage::app()->getResponse(); + $response->setRedirect($destinationUrl, 301); + $response->sendResponse(); + exit; + } + continue; + } + } + } + } + + protected function doRedirects1($requestUrl) + { + if (Mage::getStoreConfig('optimisewebredirects/redirects1/upload') AND file_exists(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/redirects1/upload'))) { + + $redirectLines = file(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/redirects1/upload')); + + foreach ($redirectLines AS $redirectLine) { + + $sourceDestination = explode(Mage::getStoreConfig('optimisewebredirects/redirects1/delimiter'), $redirectLine); + + if (count($sourceDestination) == 3) { + $sourceUrl = rtrim(trim($sourceDestination[0]), '/'); + $destinationUrl = trim($sourceDestination[1]); + $redirectCode = (int) trim($sourceDestination[2]); + + $doRedirect = FALSE; + + if ($sourceUrl == $requestUrl) { + $doRedirect = TRUE; + } elseif (strpos($sourceUrl, Mage::getStoreConfig('optimisewebredirects/redirects1/wildcardcharacter'))) { + $sourceUrl = str_replace(Mage::getStoreConfig('optimisewebredirects/redirects1/wildcardcharacter'), '', $sourceUrl); + if (strpos($requestUrl, $sourceUrl) === 0) { + $doRedirect = TRUE; + } + } + if ($doRedirect) { + $response = Mage::app()->getResponse(); + $response->setRedirect($destinationUrl, $redirectCode); + $response->sendResponse(); + exit; + } + continue; + } + } + } + } + + protected function doQueryStringRedirects($requestUrl) + { + if (Mage::getStoreConfig('optimisewebredirects/querystring/upload') AND file_exists(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/querystring/upload'))) { + + $query = parse_url($requestUrl); + $queryUrl = $query['scheme'] . '://' . $query['host'] . $query['path']; + $requestUrl = rtrim($queryUrl, '/'); + + if (array_key_exists('query', $query)) { + parse_str($query['query'], $queryParts); + } + + if (isset($queryParts) && is_array($queryParts)) { + + $redirectLines = file(Mage::getBaseDir('media') . '/optimiseweb/redirects/' . Mage::getStoreConfig('optimisewebredirects/querystring/upload')); + + foreach ($redirectLines AS $redirectLine) { + + $queryVarDestination = explode(Mage::getStoreConfig('optimisewebredirects/querystring/delimiter'), $redirectLine); + + if (count($queryVarDestination) == 5) { + $sourceUrl = rtrim(trim($queryVarDestination[0]), '/'); + $queryVar = trim($queryVarDestination[1]); + $queryValue = trim($queryVarDestination[2]); + $destinationUrl = trim($queryVarDestination[3]); + $redirectCode = (int) trim($queryVarDestination[4]); + + $doRedirect = FALSE; + + if ($sourceUrl == $requestUrl) { + $doRedirect = TRUE; + } elseif (strpos($sourceUrl, Mage::getStoreConfig('optimisewebredirects/querystring/wildcardcharacter'))) { + $sourceUrl = str_replace(Mage::getStoreConfig('optimisewebredirects/querystring/wildcardcharacter'), '', $sourceUrl); + if (strpos($requestUrl, $sourceUrl) === 0) { + $doRedirect = TRUE; + } + } + if ($doRedirect) { + if (array_key_exists($queryVar, $queryParts) AND ( $queryParts[$queryVar] == $queryValue)) { + $response = Mage::app()->getResponse(); + $response->setRedirect($destinationUrl, $redirectCode); + $response->sendResponse(); + exit; + } + } + continue; + } + } + } + } + } + + protected function doRedirectsToCatalogueSearch($requestUrl) + { + if ((bool) Mage::getStoreConfig('optimisewebredirects/cataloguesearch/enabled')) { + + $query = parse_url($requestUrl); + $queryUrl = $query['scheme'] . '://' . $query['host'] . $query['path']; + $requestUrlSlashTrimmed = rtrim($queryUrl, '/'); + $queryPath = $query['path']; + $queryPathSlashTrimmed = ltrim($queryPath, '/'); + $queryPathExploded = explode('/', $queryPathSlashTrimmed); + $queryPathLast = end($queryPathExploded); + + $searchQueryString = str_replace('.html', '', $queryPathSlashTrimmed); + $searchQueryString = str_replace('/', '+', $searchQueryString); + + $catalogueSearchUrl = Mage::helper('catalogsearch')->getResultUrl(); + $catalogueSearchQueryUrl = $catalogueSearchUrl . '?q=' . $searchQueryString; + + $response = Mage::app()->getResponse(); + $response->setRedirect($catalogueSearchQueryUrl, 301); + $response->sendResponse(); + + exit; + } + } + +} diff --git a/app/code/community/Optimiseweb/Redirects/doc/Readme.html b/app/code/community/Optimiseweb/Redirects/doc/Readme.html new file mode 100644 index 0000000..f9b6da2 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/doc/Readme.html @@ -0,0 +1,120 @@ +

Mass / Bulk Redirects (301, 302, or any status) for Magento 404 Pages

+ +

Magento has an internal URL Rewrite Management system. Magento can automatically add redirects for new and changed categories and products. However, it can be a laborious task to add all your custom redirects and/or redirects from an old website, one by one.

+ +

How does this module work?

+ +

Optimise Web's Bulk Redirects extension for Magento allows you to upload all your redirect data as a CSV file. This module is purely CSV file based (doesn't touch the database). Consider this as an alternative to adding 301 redirects into the .htaccess file.

+ +

When a missing URL is requested, Magento's routing system will first look within its database table for available rewrites. If Magento cannot find a suitable redirect, it will present your visitor with a 404 error page. This redirect module is set to work between Magento's internal check and the 404 page. When Magento cannot find a suitable redirect, this module will try and find one. If this module cannot find a matching redirect, the visitor will then be sent to the 404 page.

+ +

There are three methods of redirects that are available. They all work one after the other. The module implements a Best Match approach. If a matching redirect is found in the first method, Magento uses it and doesn't look at the rest of the CSV file or the remaining methods.

+ +

Method 1 - Legacy

+ +

I called this Legacy as it was the first option I wrote for this module. Many Magento retailers still use this option. I did not want their websites to stop working. So it is still here.

+ +

CSV Format:
+ http://www.oldurl.com/oldpath;http://www.newurl.com/newpath +
+ Notice the semicolon. In the past, this module used a semicolon to separate the URLs. Please note that this option uses just a single cell of the CSV file in Excel. +
+ A sample file is available here http://optimiseweb.co.uk/magento-modules/1-Legacy.csv +

+

Method 2 - Redirects System v1.0

+

Many retailers were struggling with the semicolon and single cell based redirects. So, I made this into a three cell redirect.

+

+ CSV Format: +
+ http://www.oldurl.com/oldpath,http://www.newurl.com/newpath,status_code +
+ Notice the comma as a separator. I have now given an option for you to customise the delimiter / separator. Excel saves the CSV using commas. However, you can choose to use any character, even a pipe delimiter. +
+ The status_code will be 301 or 302. Now this version on, you can define the status code (required for the redirects to work) as well. +
+ Another big improvement to this module is the wildcard character. You can define a wildcard character in the options screen and use it in the CSV file. +
+ e.g. http://www.oldurl.com/oldpath/*,http://www.newurl.com/newpath/newsublevel,301 +
+ This will match URL that follows http://www.oldurl.com/oldpath/ and redirect them all to http://www.newurl.com/newpath/newsublevel. +
+ A sample file is available here http://optimiseweb.co.uk/magento-modules/2-Redirects.v1.0.csv +

+

Method 2 - Query String Based Redirects

+

The query string based option was developed primarily for retailers moving away from old school ecommerce platforms that used query strings in their URLs. It can also be used by existing Magento retailers who have deleted a product attribute, stopped a Google Adwords campaign, etc.

+

+ CSV Format: +
+ http://www.oldurl.com/oldbasepath,prod_id,170,http://www.newurl.com/newproducturl,status_code +
+ The settings, delimiter, wildcard options are similar to Method 2. +
+ The second column is the query string name and the third column is the query string value. +
+ e.g. http://www.oldurl.com/oldbasepath,prod_id,170,http://www.newurl.com/newproducturl,301 +
+ This will match all of the following +
+ http://www.oldurl.com/oldbasepath?prod_id=170 +
+ http://www.oldurl.com/oldbasepath?cat_id=24&prod_id=170 +
+ http://www.oldurl.com/oldbasepath?prod_id=170&cat_id=24 +
+ Please Note: This module works on a best match basis. If you had a redirect setup for the cat_id query before the prod_id query, both the above URLs will redirect to the category page. This is because cat_id is the best match. If you setup prod_id before cat_id, then the product page would take priority. It is very rare that old ecommerce systems will call both the category id and product id in the same URL. However, I am just illustrating the best match scenario. +
+ A sample file is available here http://optimiseweb.co.uk/magento-modules/3-QueryStringBasedRedirects.csv +

+
+
+

+ + PLEASE READ THIS + +

+

+ - This module is widely tested and works on most standard Magento setups.
+ - If the module isn't working for you, you have most likely not followed the standard Magento module installation routine. Read the FAQs below.
+ - Before leaving negative feedback or writing an email to us, please check the following - Turn Off Compilation Before Installation, Clear Cache After Installation, Log Off and Log Back Into the Admin
+ - 99% of the time, when users install the module and it doesn't work, we investigate and find out that there are other problems (server issues, file and folder permissions, conflicting modules, etc.).
+ - Please note that this is a very useful, but free module. We cannot be doing email ping pong all day long. If you need us to look into a problem, send us a private message with your Magento admin (with full access rights) password and FTP details. Without this we will have to embark on a email ping pong and that takes a lot of time. We hope you will understand.
+ - Thank you very much for taking time to use our module.
+

+

+ + Features + +

+

+ - If you disable a product in Magento and add a redirect for that product via this module, the redirect will not work as according to Magento the product is still in the system. You will have to delete the product for the redirect to work. I'll look into finding a work around for this.
+
+ Download and Upload of CSV +
+ - Using the system configuration panel. System > Configuration > Optimise Web (tab) > Mass 301 Redirects
+ - Always remember to download the previously uploaded CSV and add new redirects to it. Uploading a new CSV will overwrite the old CSV and you will lose all previously uploaded 301 redirects.
+
+

+ +

Frequently asked questions

+ +

1. Why am I not seeing the system settings? Why am I getting a 404 error?

+ +

As with the installation of all Magento modules, please clear the cache folders and log out of the admin area and log back in. Please also flush your CSS and JS caches - just to be sure.

+ +

2. Should I backup Magento's files and database?

+ +

This module does not add or make database changes during the install process. But yes, please make it a point to backup your files and database before installing or upgrading any Magento module.

+ +

3. Will the module work with compilation turned on?

+ +

Yes. Still, make sure you disable compilation when installing the module. You can turn on compilation after installation and clearing the cache folders.

+ +

4. Do you offer support for this extension?

+ +

This is a free extension and support will be limited. We have placed a support link on the settings page of the module. Please write to us and we'll do our best to help you out.

+ +

Important:

+ +

To be able to develop the module further and provide better support, we capture your Magento version, module version, admin URL and admin email address when you access the admin > module settings page. We do not share this data with anyone. We do not use this data to send you marketing communication. We do this purely for support and statistical purposes.

+ +

If you do not agree to this, please do not install the module. Or, write to us to request a bespoke version of the module.

\ No newline at end of file diff --git a/app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml b/app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml new file mode 100644 index 0000000..43cfd85 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml @@ -0,0 +1,68 @@ + + + + + + + Optimise Web + 71 + + + Mass 301 Redirects + 5 + adminhtml/system_config/edit/section/optimisewebredirects + + optimisewebredirects/menu/ow_redirects_enabled + + + + + optimisewebredirects/menu/optimiseweball_enabled + + + + + + + + Allow Everything + + + + + Optimise Web - Menu Group + 10 + + + Optimise Web - Mass 301 Redirects + 10 + + + + + + + + + Optimise Web - System Configuration Group + + + Optimise Web - Mass 301 Redirects + + + + + + + + + + + \ No newline at end of file diff --git a/app/code/community/Optimiseweb/Redirects/etc/config.xml b/app/code/community/Optimiseweb/Redirects/etc/config.xml new file mode 100644 index 0000000..eee96a5 --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/etc/config.xml @@ -0,0 +1,111 @@ + + + + + + + 0.3.5 + + + + + + + + + + Optimiseweb_Redirects.csv + + + + + + + + + + + + + + Optimiseweb_Redirects.csv + + + + + + + + + + + + Optimiseweb_Redirects_Block + + + + + + Optimiseweb_Redirects_Helper + + + + + + Optimiseweb_Redirects_Model + + + + + + + + singleton + ow_redirects/redirector + doRedirects + + + + + + + + + + + + 0 + + + 0 + + + 0 + + + , + * + + + , + * + + + 0 + + + 1 + 1 + + + + + + \ No newline at end of file diff --git a/app/code/community/Optimiseweb/Redirects/etc/system.xml b/app/code/community/Optimiseweb/Redirects/etc/system.xml new file mode 100644 index 0000000..fba8e7a --- /dev/null +++ b/app/code/community/Optimiseweb/Redirects/etc/system.xml @@ -0,0 +1,355 @@ + + + + + + + + 400 + + + + + + + optimisewebconfig + ow-system-section ow-mass-301-redirects-section + ow-system-header ow-mass-301-redirects-header + text + 99999 + 1 + 1 + 1 + + + + ow_redirects/adminhtml_system_config_fieldset_hint + 0 + 1 + 1 + 1 + + + + + text + 1 + 1 + 1 + 1 + + + + + With this option set to 'Yes', you can prevent visitors of disabled products from going to a 404 page.

+ ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+
+
+ + + + text + 2 + 1 + 1 + 1 + + + + + With this option set to 'Yes', you can prevent visitors of not visible products from going to a 404 page.

+ ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+
+
+ + + + text + 3 + 1 + 1 + 1 + + + + + With this option set to 'Yes', you can prevent visitors of disabled categories from going to a 404 page.

+ ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+
+
+ + + + + +

CSV Format (takes three Excel cells):

+

http://domain.com/old-path/,http://domain.com/new-path/,301

+

You can use wildcards!

+

http://domain.com/old-*,http://domain.com/new-path/,301

+

The above example will redirect every 404 URL starting with http://domain.com/old- to http://domain.com/new-path/

+

To cater to different CSV formats, I have provided separator and wildcard customisation. Please check the CSV file by opening it in a plain text editor. Formatting errors and additional carriage returns can cause the module to stop working.

+ + ]]> +
+ text + 4 + 1 + 1 + 1 + + + + If you have already uploaded a CSV file and wish to add or edit the URLs, please download the current CSV file and reupload that file after making the changes. + file + adminhtml/system_config_backend_file + optimiseweb/redirects + optimiseweb/redirects + 1 + 1 + 1 + 1 + + + + Right click on this link and click on 'Save Link As...' + ow_redirects/system_config_backend_download1 + 2 + 1 + 1 + 1 + + + + Defaults to comma (,). Depends on how you save your CSV file. + text + 3 + 1 + 1 + 1 + + + + Defaults to asterisk (*). + text + 4 + 1 + 1 + 1 + + +
+ + + + + +

CSV Format (takes five Excel cells):

+

http://domain.com/old-base-path/,prod_id,101,http://domain.com/new-path/,301

+

The above example will match http://domain.com/old-base-path/?prod_id=101 and redirect the visitor to http://domain.com/new-path/ with a status code of 301.

+

The method uses a best match scenario. http://domain.com/old-base-path/?prod_id=101&cat_id=201 will match prod_id or cat_id, whichever comes first in the CSV.

+

You can use wildcards!

+

http://domain.com/old-*,prod_id,101,http://domain.com/new-path/,301

+ + ]]> +
+ text + 5 + 1 + 1 + 1 + + + + If you have already uploaded a CSV file and wish to add or edit the URLs, please download the current CSV file and reupload that file after making the changes. + file + adminhtml/system_config_backend_file + optimiseweb/redirects + optimiseweb/redirects + 1 + 1 + 1 + 1 + + + + Right click on this link and click on 'Save Link As...' + ow_redirects/system_config_backend_downloadquerystringfile + 2 + 1 + 1 + 1 + + + + Defaults to comma (,). Depends on how you save your CSV file. + text + 3 + 1 + 1 + 1 + + + + Defaults to asterisk (*). + text + 4 + 1 + 1 + 1 + + +
+ + + + text + 999 + 1 + 1 + 1 + + + + + The 'Optimise Web' menu group acts as a parent menu item for the various modules developed by Optimise Web. If you do not wish to see the link in the admin menu and would rather manually visit the System Config.

+ + ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+ + + + The 'Optimise Web' menu group acts as a parent menu item for the various modules developed by Optimise Web. If you do not wish to see the link in the admin menu and would rather manually visit the System Config.

+ + ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+
+
+ + + + + +

This option still works, but please consider using Redirects System v1.0 as it offers a better CSV format and supports redirect status codes.

+

CSV Format (inside one single Excel cell):

+

http://domain.com/old-path/;http://domain.com/new-path/

+

Please check the CSV file by opening it in a plain text editor. Formatting errors and additional carriage returns can cause the module to stop working.

+ + ]]> +
+ text + 9999 + 1 + 1 + 1 + + + + If you have already uploaded a CSV file and wish to add or edit the URLs, please download the current CSV file and reupload that file after making the changes. + file + adminhtml/system_config_backend_file + optimiseweb/redirects + optimiseweb/redirects + 1 + 1 + 1 + 1 + + + + Right click on this link and click on 'Save Link As...' + ow_redirects/system_config_backend_download + 2 + 1 + 1 + 1 + + +
+ + + + text + 9998 + 1 + 1 + 1 + + + + + Use this as a last resort option. Instead of landing on a 404 page, you can get the module to redirect your visitor to a search page.

+

Just a word of caution - enabling this option will make it so that there are no 404 errors on your website. This will even redirect missing images to a catalogue search.

+

At the moment, the search keyword will be triggered by breaking up the last URL path. e.g. /electronics/iphone-5s.html will trigger a search for "iphone 5s"

+

If the above 'Redirect non-404 requests?' is set to 'Yes', it overrides this option.

+

This feature is not being developed anymore.

+ ]]> +
+ select + adminhtml/system_config_source_yesno + 1 + 1 + 1 + 1 +
+
+
+ +
+
+
+ +
\ No newline at end of file diff --git a/app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml b/app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml new file mode 100644 index 0000000..5def470 --- /dev/null +++ b/app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml @@ -0,0 +1,33 @@ +
+ + + +

+ getModuleName(); ?> vgetModuleVersion(); ?> by Optimise Web +

+ +

+ Click here for this module's configuration and usage documentation +

+ +

+ Optimise Web is a Full Service Digital Agency from Edinburgh (Scotland, UK). + The author of this extension, Kathir 'Sid' Vel, is our eCommerce and Digital Marketing specialist. +

+ +

+ Need assistance? Submit a ticket. + Got feedback? Email us. + +

+ +
+ + \ No newline at end of file diff --git a/app/etc/modules/Optimiseweb_Redirects.xml b/app/etc/modules/Optimiseweb_Redirects.xml new file mode 100644 index 0000000..81cb4b2 --- /dev/null +++ b/app/etc/modules/Optimiseweb_Redirects.xml @@ -0,0 +1,17 @@ + + + + + + true + community + + + \ No newline at end of file diff --git a/app/locale/en_US/Optimiseweb_Redirects.csv b/app/locale/en_US/Optimiseweb_Redirects.csv new file mode 100644 index 0000000..e69de29 diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..320ec47 --- /dev/null +++ b/composer.json @@ -0,0 +1,14 @@ +{ + "name": "kirchbergerknorr/optimiseweb_redirects", + "description": "Mass 301 Redirects for 404 Pages", + "homepage": "https://www.magentocommerce.com/magento-connect/optimise-web-s-mass-301-redirects-for-404-pages.html", + "type": "magento-module", + "license": "OSL-3.0", + "authors": [ + { + "name": "Leo Friedrichs", + "email": "lf@kirchbergerknorr.de" + } + ], + "require": {} +} diff --git a/modman b/modman new file mode 100644 index 0000000..783baab --- /dev/null +++ b/modman @@ -0,0 +1,14 @@ +app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml app/design/adminhtml/default/default/template/optimiseweb/redirects/system/config/fieldset/hint.phtml +app/etc/modules/Optimiseweb_Redirects.xml app/etc/modules/Optimiseweb_Redirects.xml +app/code/community/Optimiseweb/Redirects/Helper/Data.php app/code/community/Optimiseweb/Redirects/Helper/Data.php +app/code/community/Optimiseweb/Redirects/Model/Redirector.php app/code/community/Optimiseweb/Redirects/Model/Redirector.php +app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php app/code/community/Optimiseweb/Redirects/Block/Adminhtml/System/Config/Fieldset/Hint.php +app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download1.php +app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Downloadquerystringfile.php +app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php app/code/community/Optimiseweb/Redirects/Block/System/Config/Backend/Download.php +app/code/community/Optimiseweb/Redirects/etc/config.xml app/code/community/Optimiseweb/Redirects/etc/config.xml +app/code/community/Optimiseweb/Redirects/etc/system.xml app/code/community/Optimiseweb/Redirects/etc/system.xml +app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml app/code/community/Optimiseweb/Redirects/etc/adminhtml.xml +app/code/community/Optimiseweb/Redirects/doc/Readme.html app/code/community/Optimiseweb/Redirects/doc/Readme.html +app/locale/en_US/Optimiseweb_Redirects.csv app/locale/en_US/Optimiseweb_Redirects.csv +composer.json composer.json