ik heb sinds ik de webwinkel heb geupdate 2 vqmod fouten
Code: Select all
2013-04-30 7:20:05 - PHP Notice: Undefined index: route in /www.koienvijvercentrum.nl/htdocs/vqmod/vqcache/vq2-catalog_controller_common_seo_url.php on line 127
Code: Select all
<?php
class ControllerCommonSeoUrl extends Controller {
public function index() {
// Add rewrite to url class
if ($this->config->get('config_seo_url')) {
$this->url->addRewrite($this);
}
// Decode URL
if (isset($this->request->get['_route_'])) {
$lquery = $this->db->query("SELECT * FROM " . DB_PREFIX . "language;");
foreach ($lquery->rows as $language) {
if ((strpos($this->request->get['_route_'],$language['code'].'/')) === 0) {
$this->session->data['language'] = $language['code'];
$this->language = new Language($language['directory']);
$this->language->load($language['filename']);
$this->registry->set('language', $this->language);
$this->config->set('config_language_id', $language['language_id']);
$this->request->get['_route_'] = ltrim( $this->request->get['_route_'], $language['code'].'/');
}
}
if ($this->request->get['_route_'] == '') {unset($this->request->get['_route_']);}
}
if (isset($this->request->get['_route_'])) {
$parts = explode('/', $this->request->get['_route_']);
foreach ($parts as $part) {
$query = $this->db->query("SELECT u.query, u.keyword, u.language_id as lid, l.code, l.filename, l.directory FROM " . DB_PREFIX . "url_alias u left join " . DB_PREFIX . "language l on u.language_id = l.language_id WHERE u.keyword = '" . $this->db->escape($part) . "'");
if ($query->num_rows) {
$url = explode('=', $query->row['query']);
if ($url[0] == 'product_id') {
if (($this->session->data['language'] <> $query->row['code']) || (!isset($this->session->data['language'])))
{
$this->session->data['language'] = $query->row['code'];
$this->language = new Language($query->row['directory']);
$this->language->load($query->row['filename']);
$this->registry->set('language', $this->language);
$this->config->set('config_language_id', $query->row['lid']);
}
$this->request->get['product_id'] = $url[1];
}
if ($url[0] == 'category_id') {
if (($this->session->data['language'] <> $query->row['code']) || (!isset($this->session->data['language'])))
{
$this->session->data['language'] = $query->row['code'];
$this->language = new Language($query->row['directory']);
$this->language->load($query->row['filename']);
$this->registry->set('language', $this->language);
$this->config->set('config_language_id', $query->row['lid']);
}
if (!isset($this->request->get['path'])) {
$this->request->get['path'] = $url[1];
} else {
$this->request->get['path'] .= '_' . $url[1];
}
}
if ($url[0] == 'manufacturer_id') {
if (($this->session->data['language'] <> $query->row['code']) || (!isset($this->session->data['language'])))
{
$this->session->data['language'] = $query->row['code'];
$this->language = new Language($query->row['directory']);
$this->language->load($query->row['filename']);
$this->registry->set('language', $this->language);
$this->config->set('config_language_id', $query->row['lid']);
}
$this->request->get['manufacturer_id'] = $url[1];
}
if ($url[0] == 'information_id') {
if (($this->session->data['language'] <> $query->row['code']) || (!isset($this->session->data['language'])))
{
$this->session->data['language'] = $query->row['code'];
$this->language = new Language($query->row['directory']);
$this->language->load($query->row['filename']);
$this->registry->set('language', $this->language);
$this->config->set('config_language_id', $query->row['lid']);
}
$this->request->get['information_id'] = $url[1];
}
} else {
$this->request->get['route'] = 'error/not_found';
}
}
if (isset($this->request->get['product_id'])) {
$this->request->get['route'] = 'product/product'; $this->session->data['product_id'] = $this->request->get['product_id'];
} elseif ($this->request->get['_route_'] == 'wishlist') { $this->request->get['route'] = 'account/wishlist';
} elseif ($this->request->get['_route_'] == 'contact') { $this->request->get['route'] = 'information/contact';
} elseif ($this->request->get['_route_'] == 'account') { $this->request->get['route'] = 'account/account';
} elseif ($this->request->get['_route_'] == 'sitemap') { $this->request->get['route'] = 'information/sitemap';
} elseif ($this->request->get['_route_'] == 'manufacturer') { $this->request->get['route'] = 'product/manufacturer';
} elseif ($this->request->get['_route_'] == 'affiliates') { $this->request->get['route'] = 'affiliate/account';
} elseif ($this->request->get['_route_'] == 'special') { $this->request->get['route'] = 'product/special';
} elseif ($this->request->get['_route_'] == 'login') { $this->request->get['route'] = 'account/login';
} elseif ($this->request->get['_route_'] == 'logout') { $this->request->get['route'] = 'account/logout';
} elseif ($this->request->get['_route_'] == 'register') { $this->request->get['route'] = 'account/register';
} elseif (isset($this->request->get['path'])) {
$this->request->get['route'] = 'product/category'; $this->session->data['path'] = $this->request->get['path'];
} elseif (isset($this->request->get['manufacturer_id'])) {
$this->request->get['route'] = 'product/manufacturer/info'; $this->session->data['manufacturer_id'] = $this->request->get['manufacturer_id'];
} elseif (isset($this->request->get['information_id'])) {
$this->request->get['route'] = 'information/information'; $this->session->data['information_id'] = $this->request->get['information_id'];
}
127: $this->session->data[
'proute'] = $this->request->get['route'];
if (isset($this->request->get['route'])) {
return $this->forward($this->request->get['route']);
}
}
}
public function rewrite($link) {
if ($this->config->get('config_seo_url')) {
$url_data = parse_url(str_replace('&', '&', $link));
$squery = $this->db->query("SELECT `value` FROM `" . DB_PREFIX . "setting` WHERE `key` = 'config_language'");
if (isset($this->session->data['language']) && ($this->session->data['language'] <> $squery->row['value'])) {$url = '/'.$this->session->data['language'];}
else {$url = '';}
$data = array();
parse_str($url_data['query'], $data);
foreach ($data as $key => $value) {
if (isset($data['route'])) {
if (($data['route'] == 'product/product' && $key == 'product_id') || (($data['route'] == 'product/manufacturer/info' || $data['route'] == 'product/product') && $key == 'manufacturer_id') || ($data['route'] == 'information/information' && $key == 'information_id')) {
$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "url_alias WHERE language_id = " . (int)$this->config->get('config_language_id') . " AND `query` = '" . $this->db->escape($key . '=' . (int)$value) . "'");
if ($query->num_rows) {
$url .= '/' . $query->row['keyword'];
unset($data[$key]);
}
} elseif (isset($data['route']) && $data['route'] == 'common/home') { $url .= '/';
} elseif (isset($data['route']) && $data['route'] == 'account/wishlist' && $key != 'remove') { $url .= '/wishlist';
} elseif (isset($data['route']) && $data['route'] == 'information/contact') { $url .= '/contact';
} elseif (isset($data['route']) && $data['route'] == 'account/account') { $url .= '/account';
} elseif (isset($data['route']) && $data['route'] == 'information/sitemap') { $url .= '/sitemap';
} elseif (isset($data['route']) && $data['route'] == 'product/manufacturer') { $url .= '/manufacturer';
} elseif (isset($data['route']) && $data['route'] == 'affiliate/account') { $url .= '/affiliates';
} elseif (isset($data['route']) && $data['route'] == 'product/special' && $key != 'page' && $key != 'sort' && $key != 'limit' && $key != 'order') { $url .= '/special';
} elseif (isset($data['route']) && $data['route'] == 'account/login') { $url .= '/login';
} elseif (isset($data['route']) && $data['route'] == 'account/logout') { $url .= '/logout';
} elseif (isset($data['route']) && $data['route'] == 'account/register') { $url .= '/register';
} elseif ($key == 'path') {
$categories = explode('_', $value);
foreach ($categories as $category) {
$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "url_alias WHERE language_id = " . (int)$this->config->get('config_language_id') . " AND `query` = 'category_id=" . (int)$category . "'");
if ($query->num_rows) {
$url .= '/' . $query->row['keyword'];
}
}
unset($data[$key]);
}
}
}
if (($url) && ($url <> '/'.$this->session->data['language'])){
unset($data['route']);
$query = '';
if ($data) {
foreach ($data as $key => $value) {
$query .= '&' . $key . '=' . $value;
}
if ($query) {
$query = '?' . trim($query, '&');
}
}
return $url_data['scheme'] . '://' . $url_data['host'] . (isset($url_data['port']) ? ':' . $url_data['port'] : '') . str_replace('/index.php', '', $url_data['path']) . $url . $query;
} else {
return $link;
}
} else {
return $link;
}
}
}
?>