Skip to content
Browse files

Introduce Canonical Header Tags module

Used currently for category listings and product information page
  • Loading branch information...
1 parent 5a98751 commit 9f354d2992e55e9d27cc6d70baca1125a968c23b @haraldpdl haraldpdl committed Aug 3, 2012
View
15 catalog/includes/languages/english/modules/header_tags/ht_canonical.php
@@ -0,0 +1,15 @@
+<?php
+/*
+ $Id$
+
+ osCommerce, Open Source E-Commerce Solutions
+ http://www.oscommerce.com
+
+ Copyright (c) 2012 osCommerce
+
+ Released under the GNU General Public License
+*/
+
+ define('MODULE_HEADER_TAGS_CANONICAL_TITLE', 'Canonical Header Links');
+ define('MODULE_HEADER_TAGS_CANONICAL_DESCRIPTION', 'Add header canonical links to category and product pages');
+?>
View
62 catalog/includes/modules/header_tags/ht_canonical.php
@@ -0,0 +1,62 @@
+<?php
+/*
+ $Id$
+
+ osCommerce, Open Source E-Commerce Solutions
+ http://www.oscommerce.com
+
+ Copyright (c) 2012 osCommerce
+
+ Released under the GNU General Public License
+*/
+
+ class ht_canonical {
+ var $code = 'ht_canonical';
+ var $group = 'header_tags';
+ var $title;
+ var $description;
+ var $sort_order;
+ var $enabled = false;
+
+ function ht_canonical() {
+ $this->title = MODULE_HEADER_TAGS_CANONICAL_TITLE;
+ $this->description = MODULE_HEADER_TAGS_CANONICAL_DESCRIPTION;
+
+ if ( defined('MODULE_HEADER_TAGS_CANONICAL_STATUS') ) {
+ $this->sort_order = MODULE_HEADER_TAGS_CANONICAL_SORT_ORDER;
+ $this->enabled = (MODULE_HEADER_TAGS_CANONICAL_STATUS == 'True');
+ }
+ }
+
+ function execute() {
+ global $PHP_SELF, $HTTP_GET_VARS, $cPath, $oscTemplate;
+
+ if (basename($PHP_SELF) == FILENAME_PRODUCT_INFO) {
+ $oscTemplate->addBlock('<link rel="canonical" href="' . tep_href_link(FILENAME_PRODUCT_INFO, 'products_id=' . $HTTP_GET_VARS['products_id'], 'NONSSL', false) . '" />' . "\n", $this->group);
+ } elseif ((basename($PHP_SELF) == FILENAME_DEFAULT) && isset($cPath) && tep_not_null($cPath)) {
+ $oscTemplate->addBlock('<link rel="canonical" href="' . tep_href_link(FILENAME_DEFAULT, 'cPath=' . $cPath, 'NONSSL', false) . '" />' . "\n", $this->group);
+ }
+ }
+
+ function isEnabled() {
+ return $this->enabled;
+ }
+
+ function check() {
+ return defined('MODULE_HEADER_TAGS_CANONICAL_STATUS');
+ }
+
+ function install() {
+ tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Enable Canonical Module', 'MODULE_HEADER_TAGS_CANONICAL_STATUS', 'True', 'Do you want to enable the Canonical module?', '6', '1', 'tep_cfg_select_option(array(\'True\', \'False\'), ', now())");
+ tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort Order', 'MODULE_HEADER_TAGS_CANONICAL_SORT_ORDER', '0', 'Sort order of display. Lowest is displayed first.', '6', '0', now())");
+ }
+
+ function remove() {
+ tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')");
+ }
+
+ function keys() {
+ return array('MODULE_HEADER_TAGS_CANONICAL_STATUS', 'MODULE_HEADER_TAGS_CANONICAL_SORT_ORDER');
+ }
+ }
+?>

0 comments on commit 9f354d2

Please sign in to comment.
Something went wrong with that request. Please try again.