карта сайта
This commit is contained in:
@@ -24,7 +24,6 @@ RewriteEngine On
|
|||||||
RewriteBase /
|
RewriteBase /
|
||||||
RewriteCond %{QUERY_STRING} ^(.*)&?page=1$
|
RewriteCond %{QUERY_STRING} ^(.*)&?page=1$
|
||||||
RewriteRule ^(.*)/?$ /$1?%1%2 [R=301,L] #remove page=1 from url
|
RewriteRule ^(.*)/?$ /$1?%1%2 [R=301,L] #remove page=1 from url
|
||||||
RewriteRule ^sitemap.xml$ index.php?route=extension/feed/google_sitemap [L]
|
|
||||||
RewriteRule ^googlebase.xml$ index.php?route=extension/feed/google_base [L]
|
RewriteRule ^googlebase.xml$ index.php?route=extension/feed/google_base [L]
|
||||||
RewriteRule ^system/storage/(.*) index.php?route=error/not_found [L]
|
RewriteRule ^system/storage/(.*) index.php?route=error/not_found [L]
|
||||||
RewriteCond %{REQUEST_FILENAME} !-f
|
RewriteCond %{REQUEST_FILENAME} !-f
|
||||||
|
|||||||
@@ -7,21 +7,28 @@ class ControllerExtensionFeedGoogleSitemap extends Controller {
|
|||||||
|
|
||||||
$this->load->model('catalog/product');
|
$this->load->model('catalog/product');
|
||||||
$this->load->model('tool/image');
|
$this->load->model('tool/image');
|
||||||
|
$this->load->model('localisation/zone');
|
||||||
|
|
||||||
$products = $this->model_catalog_product->getProducts();
|
$products = $this->model_catalog_product->getProducts();
|
||||||
|
$zones = $this->model_localisation_zone->getZonesByCountryId($this->config->get('config_country_id'));
|
||||||
|
|
||||||
|
if (!$zones) {
|
||||||
|
$zones[] = $this->model_localisation_zone->getZone($this->config->get('config_zone_id'));
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($products as $product) {
|
foreach ($products as $product) {
|
||||||
if ($product['image']) {
|
$product_url = $this->url->link('product/product', 'product_id=' . $product['product_id']);
|
||||||
|
|
||||||
|
if (!$this->hasSeoUrl($product_url)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($zones as $zone) {
|
||||||
$output .= '<url>';
|
$output .= '<url>';
|
||||||
$output .= ' <loc>' . $this->url->link('product/product', 'product_id=' . $product['product_id']) . '</loc>';
|
$output .= ' <loc>' . $this->escapeUrl($this->model_localisation_zone->getZoneUrlByZone($zone, $product_url)) . '</loc>';
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
$output .= ' <changefreq>weekly</changefreq>';
|
||||||
$output .= ' <lastmod>' . date('Y-m-d\TH:i:sP', strtotime($product['date_modified'])) . '</lastmod>';
|
$output .= ' <lastmod>' . date('Y-m-d\TH:i:sP', strtotime($product['date_modified'])) . '</lastmod>';
|
||||||
$output .= ' <priority>1.0</priority>';
|
$output .= ' <priority>1.0</priority>';
|
||||||
$output .= ' <image:image>';
|
|
||||||
$output .= ' <image:loc>' . $this->model_tool_image->resize($product['image'], $this->config->get('theme_' . $this->config->get('config_theme') . '_image_popup_width'), $this->config->get('theme_' . $this->config->get('config_theme') . '_image_popup_height')) . '</image:loc>';
|
|
||||||
$output .= ' <image:caption>' . $product['name'] . '</image:caption>';
|
|
||||||
$output .= ' <image:title>' . $product['name'] . '</image:title>';
|
|
||||||
$output .= ' </image:image>';
|
|
||||||
$output .= '</url>';
|
$output .= '</url>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -36,20 +43,11 @@ class ControllerExtensionFeedGoogleSitemap extends Controller {
|
|||||||
|
|
||||||
foreach ($manufacturers as $manufacturer) {
|
foreach ($manufacturers as $manufacturer) {
|
||||||
$output .= '<url>';
|
$output .= '<url>';
|
||||||
$output .= ' <loc>' . $this->url->link('product/manufacturer/info', 'manufacturer_id=' . $manufacturer['manufacturer_id']) . '</loc>';
|
$output .= ' <loc>' . $this->escapeUrl($this->url->link('product/manufacturer/info', 'manufacturer_id=' . $manufacturer['manufacturer_id'])) . '</loc>';
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
$output .= ' <changefreq>weekly</changefreq>';
|
||||||
$output .= ' <priority>0.7</priority>';
|
$output .= ' <priority>0.7</priority>';
|
||||||
$output .= '</url>';
|
$output .= '</url>';
|
||||||
|
|
||||||
$products = $this->model_catalog_product->getProducts(array('filter_manufacturer_id' => $manufacturer['manufacturer_id']));
|
|
||||||
|
|
||||||
foreach ($products as $product) {
|
|
||||||
$output .= '<url>';
|
|
||||||
$output .= ' <loc>' . $this->url->link('product/product', 'manufacturer_id=' . $manufacturer['manufacturer_id'] . '&product_id=' . $product['product_id']) . '</loc>';
|
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
|
||||||
$output .= ' <priority>1.0</priority>';
|
|
||||||
$output .= '</url>';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->load->model('catalog/information');
|
$this->load->model('catalog/information');
|
||||||
@@ -58,7 +56,7 @@ class ControllerExtensionFeedGoogleSitemap extends Controller {
|
|||||||
|
|
||||||
foreach ($informations as $information) {
|
foreach ($informations as $information) {
|
||||||
$output .= '<url>';
|
$output .= '<url>';
|
||||||
$output .= ' <loc>' . $this->url->link('information/information', 'information_id=' . $information['information_id']) . '</loc>';
|
$output .= ' <loc>' . $this->escapeUrl($this->url->link('information/information', 'information_id=' . $information['information_id'])) . '</loc>';
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
$output .= ' <changefreq>weekly</changefreq>';
|
||||||
$output .= ' <priority>0.5</priority>';
|
$output .= ' <priority>0.5</priority>';
|
||||||
$output .= '</url>';
|
$output .= '</url>';
|
||||||
@@ -84,24 +82,22 @@ class ControllerExtensionFeedGoogleSitemap extends Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$output .= '<url>';
|
$output .= '<url>';
|
||||||
$output .= ' <loc>' . $this->url->link('product/category', 'path=' . $new_path) . '</loc>';
|
$output .= ' <loc>' . $this->escapeUrl($this->url->link('product/category', 'path=' . $new_path)) . '</loc>';
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
$output .= ' <changefreq>weekly</changefreq>';
|
||||||
$output .= ' <priority>0.7</priority>';
|
$output .= ' <priority>0.7</priority>';
|
||||||
$output .= '</url>';
|
$output .= '</url>';
|
||||||
|
|
||||||
$products = $this->model_catalog_product->getProducts(array('filter_category_id' => $result['category_id']));
|
|
||||||
|
|
||||||
foreach ($products as $product) {
|
|
||||||
$output .= '<url>';
|
|
||||||
$output .= ' <loc>' . $this->url->link('product/product', 'path=' . $new_path . '&product_id=' . $product['product_id']) . '</loc>';
|
|
||||||
$output .= ' <changefreq>weekly</changefreq>';
|
|
||||||
$output .= ' <priority>1.0</priority>';
|
|
||||||
$output .= '</url>';
|
|
||||||
}
|
|
||||||
|
|
||||||
$output .= $this->getCategories($result['category_id'], $new_path);
|
$output .= $this->getCategories($result['category_id'], $new_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $output;
|
return $output;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function escapeUrl($url) {
|
||||||
|
return htmlspecialchars(html_entity_decode($url, ENT_QUOTES, 'UTF-8'), ENT_QUOTES | ENT_XML1, 'UTF-8');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function hasSeoUrl($url) {
|
||||||
|
return basename((string)parse_url(str_replace('&', '&', $url), PHP_URL_PATH)) !== 'index.php';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -90,6 +90,10 @@ class ModelLocalisationZone extends Model {
|
|||||||
public function getZoneUrl($zone_id, $url) {
|
public function getZoneUrl($zone_id, $url) {
|
||||||
$zone = $this->getZone($zone_id);
|
$zone = $this->getZone($zone_id);
|
||||||
|
|
||||||
|
return $this->getZoneUrlByZone($zone, $url);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getZoneUrlByZone($zone, $url) {
|
||||||
if (!$zone) {
|
if (!$zone) {
|
||||||
return $url;
|
return $url;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user