ave-cms/inc/sitemap.php

193 lines
5.5 KiB
PHP
Raw Normal View History

2017-06-24 00:58:56 +03:00
<?php
2017-09-21 09:50:14 +03:00
/**
* AVE.cms
*
* @package AVE.cms
* @version 3.x
* @filesource
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
*
* @license GPL v.2
*/
2017-06-24 00:58:56 +03:00
2018-03-26 10:33:20 +03:00
define ('START_MICROTIME', microtime());
2017-06-24 00:58:56 +03:00
2018-05-19 09:15:15 +03:00
define ('BASE_DIR', str_replace("\\", "/", rtrim($_SERVER['DOCUMENT_ROOT'], '/')));
2017-06-24 00:58:56 +03:00
2020-05-07 10:16:15 +03:00
define ('USE_STATIC_DATA', false);
2018-05-16 23:14:07 +03:00
if (! @filesize(BASE_DIR . '/config/db.config.php'))
2017-09-21 09:50:14 +03:00
{
2018-03-26 10:33:20 +03:00
header ('Location: Location:install/index.php');
2017-09-21 09:50:14 +03:00
exit;
}
2017-06-24 00:58:56 +03:00
2017-09-21 09:50:14 +03:00
if (substr($_SERVER['REQUEST_URI'], 0, strlen('/index.php?')) != '/index.php?')
2018-03-26 10:33:20 +03:00
$_SERVER['REQUEST_URI'] = str_ireplace('_','-',$_SERVER['REQUEST_URI']);
2017-06-24 00:58:56 +03:00
2017-09-21 09:50:14 +03:00
require_once (BASE_DIR . '/inc/init.php');
2017-06-24 00:58:56 +03:00
2017-10-02 11:50:22 +03:00
$abs_path = str_ireplace(BASE_DIR, '/', str_replace("\\", "/", dirname(dirname(__FILE__))));
2017-06-24 00:58:56 +03:00
2018-03-26 10:33:20 +03:00
// Проверяем настройку на публикацию документов
2017-09-21 09:50:14 +03:00
$publish = get_settings('use_doctime')
2018-03-26 10:33:20 +03:00
? 'AND doc.document_published < UNIX_TIMESTAMP() AND doc.document_expire > UNIX_TIMESTAMP()'
2017-09-21 09:50:14 +03:00
: '';
2017-06-24 00:58:56 +03:00
2018-03-26 10:33:20 +03:00
// Начало
$_start = 0;
// Конец
$_end = 2000;
// Часть
$parts = 1;
2017-06-24 00:58:56 +03:00
$changefreq = array(
'0' => 'always',
'1' => 'hourly',
'2' => 'daily',
'3' => 'weekly',
'4' => 'monthly',
'5' => 'yearly',
'6' => 'never'
);
2018-05-19 20:30:18 +03:00
if (! isset($_REQUEST['id'])):
2018-03-26 10:33:20 +03:00
// Вытаскиваем кол-во документов
$sql = "
2018-05-19 09:15:15 +03:00
SELECT STRAIGHT_JOIN
2018-05-16 23:14:07 +03:00
COUNT(doc.Id) AS count
2018-03-26 10:33:20 +03:00
FROM
2018-05-19 09:15:15 +03:00
" . PREFIX . "_documents AS doc
2018-03-26 10:33:20 +03:00
LEFT JOIN
2018-05-19 09:15:15 +03:00
" . PREFIX . "_rubrics AS rub
2018-03-26 10:33:20 +03:00
ON rub.Id = doc.rubric_id
LEFT JOIN
2018-05-19 09:15:15 +03:00
" . PREFIX . "_rubric_templates AS tmpl
ON tmpl.rubric_id = rub.Id
LEFT JOIN
" . PREFIX . "_rubric_permissions AS rubperm
ON rubperm.rubric_id = rub.Id
2018-03-26 10:33:20 +03:00
WHERE
2018-05-19 09:15:15 +03:00
# Не пустой шаблон
(rub.rubric_template NOT LIKE '' OR tmpl.template NOT LIKE '')
# Статус документа = 1
2018-03-26 10:33:20 +03:00
AND doc.document_status = 1
2018-05-19 09:15:15 +03:00
# Документ не удален
2018-03-26 10:33:20 +03:00
AND doc.document_deleted = 1
$publish
2018-05-19 09:15:15 +03:00
# Документ не равен 1
AND doc.Id != 1
# Документ не равен 404 ошибке
2018-03-26 10:33:20 +03:00
AND doc.Id != " . PAGE_NOT_FOUND_ID . "
2018-05-19 09:15:15 +03:00
# Документы разрешены для индексации
2018-03-26 10:33:20 +03:00
AND (document_meta_robots NOT LIKE '%noindex%' or document_meta_robots NOT LIKE '%nofollow%')
2018-05-19 09:15:15 +03:00
# Разрешены для просмотра гостям
2018-03-26 10:33:20 +03:00
AND (rubperm.user_group_id = 2 AND rubperm.rubric_permission LIKE '%docread%')
";
2018-05-16 23:14:07 +03:00
$num = $AVE_DB->Query($sql, SITEMAP_CACHE_LIFETIME, 'sitemap')->GetCell();
2018-03-26 10:33:20 +03:00
if ($num > $_end)
$parts = ceil($num/$_end);
2018-05-19 20:30:18 +03:00
header ('Content-type: text/xml');
2018-03-26 10:33:20 +03:00
echo '<?xml version="1.0" encoding="UTF-8"?>' . PHP_EOL;
echo '<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">' . PHP_EOL;
for ($i = 1; $i <= $parts; $i++):
?>
<sitemap>
2018-05-19 09:15:15 +03:00
<loc><?php echo HOST . '/sitemap-' . $i . '.xml'; ?></loc>
<lastmod><?php echo date("c"); ?></lastmod>
2018-03-26 10:33:20 +03:00
</sitemap>
2018-05-19 09:15:15 +03:00
<?php endfor;
2018-03-26 10:33:20 +03:00
echo '</sitemapindex>';
else:
?>
2018-05-19 09:15:15 +03:00
<?php
2018-03-26 10:33:20 +03:00
if ((int)$_REQUEST['id'] > 1)
$_start = ((int)$_REQUEST['id']-1) * $_end;
$sql = "
2018-05-19 09:15:15 +03:00
SELECT STRAIGHT_JOIN
2018-03-26 10:33:20 +03:00
doc.Id,
doc.document_alias,
doc.document_published,
doc.document_changed,
doc.document_sitemap_freq,
doc.document_sitemap_pr
2018-05-19 09:15:15 +03:00
FROM
" . PREFIX . "_documents AS doc
LEFT JOIN
" . PREFIX . "_rubrics AS rub
2018-03-26 10:33:20 +03:00
ON rub.Id = doc.rubric_id
2018-05-19 09:15:15 +03:00
LEFT JOIN
" . PREFIX . "_rubric_templates AS tmpl
ON tmpl.rubric_id = rub.Id
LEFT JOIN
" . PREFIX . "_rubric_permissions AS rubperm
ON rubperm.rubric_id = rub.Id
2018-03-26 10:33:20 +03:00
WHERE
2018-05-19 09:15:15 +03:00
# Не пустой шаблон
(rub.rubric_template NOT LIKE '' OR tmpl.template NOT LIKE '')
# Статус документа = 1
2018-03-26 10:33:20 +03:00
AND doc.document_status = 1
2018-05-19 09:15:15 +03:00
# Документ не удален
2018-03-26 10:33:20 +03:00
AND doc.document_deleted = 1
$publish
2018-05-19 09:15:15 +03:00
# Документ не равен 1
2018-05-16 23:14:07 +03:00
AND doc.Id != 1
2018-05-19 09:15:15 +03:00
# Документ не равен 404 ошибке
2018-03-26 10:33:20 +03:00
AND doc.Id != " . PAGE_NOT_FOUND_ID . "
2018-05-19 09:15:15 +03:00
# Документы разрешены для индексации
2018-03-26 10:33:20 +03:00
AND (document_meta_robots NOT LIKE '%noindex%' or document_meta_robots NOT LIKE '%nofollow%')
2018-05-19 09:15:15 +03:00
# Разрешены для просмотра гостям
2018-03-26 10:33:20 +03:00
AND (rubperm.user_group_id = 2 AND rubperm.rubric_permission LIKE '%docread%')
2018-05-19 09:15:15 +03:00
GROUP BY doc.Id
2018-03-26 10:33:20 +03:00
ORDER BY doc.document_published ASC
2018-05-19 09:15:15 +03:00
LIMIT ".$_start.",".$_end.";
2018-03-26 10:33:20 +03:00
";
2018-05-19 20:30:18 +03:00
$res = $AVE_DB->Query($sql, SITEMAP_CACHE_LIFETIME, 'sitemap', true, '.limit');
2018-05-23 19:32:14 +03:00
if (! $res->NumRows() && (int)$_REQUEST['id'] != 1)
2018-05-19 20:30:18 +03:00
{
report404();
$AVE_DB->clearCurrentCache('sitemap', $sql, '.limit');
header ($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found', true);
exit;
}
header ('Content-type: text/xml');
2017-06-24 00:58:56 +03:00
2018-03-26 10:33:20 +03:00
echo '<?xml version="1.0" encoding="UTF-8"?>' . PHP_EOL;
echo '<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">' . PHP_EOL;
if ((int)$_REQUEST['id'] == 1):
?>
<url>
2018-05-19 09:15:15 +03:00
<loc><?php echo HOST . '/'; ?></loc>
<lastmod><?php echo date("c", time()); ?></lastmod>
2018-03-26 10:33:20 +03:00
<changefreq>weekly</changefreq>
<priority>0.8</priority>
</url>
2018-05-19 09:15:15 +03:00
<?php endif; ?>
<?php
2018-03-26 10:33:20 +03:00
while($row = $res->FetchAssocArray()):
2017-10-02 11:50:22 +03:00
$document_alias = $abs_path . $row['document_alias'] . URL_SUFF;
2018-05-16 23:14:07 +03:00
$document_alias = HOST . str_ireplace($abs_path . '/' . URL_SUFF, '/', $document_alias);
2018-03-26 10:33:20 +03:00
$date = $row["document_published"] ? date("c", $row["document_published"]) : date("c");
2017-06-24 00:58:56 +03:00
?>
<url>
2018-05-19 09:15:15 +03:00
<loc><?php echo $document_alias; ?></loc>
<lastmod><?php echo $date; ?></lastmod>
<changefreq><?php echo $changefreq[$row['document_sitemap_freq']]; ?></changefreq>
<priority><?php echo $row['document_sitemap_pr']; ?></priority>
2017-06-24 00:58:56 +03:00
</url>
2018-05-19 09:15:15 +03:00
<?php endwhile; ?>
2018-03-26 10:33:20 +03:00
</urlset>
2018-05-19 09:15:15 +03:00
<?php endif; ?>