Sitemap.xml generator for Yii2
, (*1)
Yii2 extension to generate sitemap files for large web-sites through Yii2 console command, (*2)
Installation
The preferred way to install this extension is through composer., (*3)
``` bash
$ php composer.phar require zhelyabuzhsky/yii2-sitemap, (*4)
or add
"zhelyabuzhsky/yii2-sitemap": "^1.1", (*5)
to the require section of your `composer.json` file.
## Features
* Generates multiple sitemaps (large sites)
* Creates index sitemap file
* Gzip compression of .xml files
* Disallow urls support (through regular expression array)
## Configuration
### 1. Configure `urlManager` at console config
```php
'urlManager' => [
'hostInfo' => 'https://example.com',
'baseUrl' => '/',
'rules' => [
// ...
],
],
NOTE Both params hostInfo
and baseUrl
are required for Yii2 console app., (*6)
NOTE urlManager
rules
section usually repeats your frontend urlManager
configuration, so you could merge it at console config (see https://github.com/yiisoft/yii2/issues/1578#issuecomment-66716648):, (*7)
Show details
, (*8)
console/main.php
, (*9)
$frontendUrlManager = require(__DIR__ . '/../../frontend/config/UrlManager.php');
//...
'urlManager' => array_merge($frontendUrlManager, [
'hostInfo' => 'https://example.com'
]),
frontend/config/UrlManager.php
, (*10)
'/',
'class' => 'yii\web\UrlManager',
'enablePrettyUrl' => true,
'showScriptName' => false,
'rules' => [
//...
],
];
?>
, (*11)
'components' => [
'sitemap' => [
'class' => '\zhelyabuzhsky\sitemap\components\Sitemap',
],
],
Example of using extra Sitemap
params, (*12)
'components' => [
'sitemap' => [
'class' => '\zhelyabuzhsky\sitemap\components\Sitemap',
'maxUrlsCountInFile' => 10000,
'sitemapDirectory' => 'frontend/web',
'optionalAttributes' => ['changefreq', 'lastmod', 'priority'],
'maxFileSize' => '10M',
],
],
where
* maxUrlsCountInFile
- max count of urls in one sitemap file;
* sitemapDirectory
- directory to place sitemap files;
* optionalAttributes
- list of used optional attributes;
* maxFileSize
- maximal file size. Zero to work without limits. So you can specify the following abbreviations k - kilobytes and m - megabytes. By default 10m., (*13)
Usage
1. Impement SitemapEntityInterface
for the models you want to use at sitemap
Show example
, (*14)
common\models\Category.php
, (*15)
use yii\db\ActiveRecord;
use zhelyabuzhsky\sitemap\models\SitemapEntityInterface;
class Category extends ActiveRecord implements SitemapEntityInterface
{
/**
* @inheritdoc
*/
public function getSitemapLastmod()
{
return date('c');
}
/**
* @inheritdoc
*/
public function getSitemapChangefreq()
{
return 'daily';
}
/**
* @inheritdoc
*/
public function getSitemapPriority()
{
return 0.5;
}
/**
* @inheritdoc
*/
public function getSitemapLoc()
{
// Use urlManager rules to create urls
return $url = Yii::$app->urlManager->createAbsoluteUrl([
'page/view',
'pageSlug' => $this->slug,
]);
// or directly
// return 'http://localhost/' . $this->slug;
}
/**
* @inheritdoc
*/
public static function getSitemapDataSource()
{
return self::find();
}
}
, (*16)
use yii\console\Controller;
class SitemapController extends Controller
{
public function actionCreate()
{
\Yii::$app->sitemap
->addModel(Item::className())
->addModel(Category::className(), \Yii::$app->db) // Also you can pass \yii\db\Connection to the database connection that you need to use
->setDisallowUrls([
'#url1#',
'#url2$#',
])
->create();
}
}
3. Run console command
php yii sitemap/create
Testing
Set enviroment variable SERVER_NAME (e.g. https://example.com), (*17)
bash
$ ./vendor/bin/phpunit
, (*18)
Security
If you discover any security related issues, please email zhelyabuzhsky@icloud.com instead of using the issue tracker., (*19)
Credits
License
GNU General Public License, version 3. Please see License File for more information., (*20)