2017 © Pedro Peláez
 

yii2-extension yii2-sitemap-module

Yii2 module for automatically generation XML Sitemap

image

katech91/yii2-sitemap-module

Yii2 module for automatically generation XML Sitemap

  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 37 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

XML Sitemap Module for Yii2

Yii2 module for automatically generating XML Sitemap., (*1)

Installation

The preferred way to install this extension is through composer., (*2)

  • Either run
php composer.phar require --prefer-dist "katech91/yii2-sitemap-module" "*"

or add, (*3)

"katech91/yii2-sitemap-module" : "*"

to the require section of your application's composer.json file., (*4)

  • Configure the cache component of your application's configuration file, for example:
'components' => [
    'cache' => [
        'class' => 'yii\caching\FileCache',
    ],
]
  • Add a new module in modules section of your application's configuration file, for example:
'modules' => [
    'sitemap' => [
        'class' => 'katech91\sitemap\Sitemap',
        'models' => [
            // your models
            'news' => 'app\modules\news\models\News',
            // or configuration for creating a behavior
            'news' => [
                'class' => 'app\modules\news\models\News',
                'behaviors' => [
                    'sitemap' => [
                        'class' => SitemapBehavior::className(),
                        'scope' => function ($model) {
                            /** @var \yii\db\ActiveQuery $model */
                            $model->select(['url', 'lastmod']);
                            $model->andWhere(['is_deleted' => 0]);
                        },
                        'dataClosure' => function ($model) {
                            /** @var self $model */
                            return [
                                'loc' => Url::to($model->url, true),
                                'lastmod' => strtotime($model->lastmod),
                                'changefreq' => SitemapBehavior::CHANGEFREQ_DAILY,
                                'priority' => 0.8
                            ];
                        }
                    ],
                ],
            ],
        ],
        'urls'=> [
            // your additional urls
            [
                'loc' => '/news/index',
                'changefreq' => \katech91\sitemap\behaviors\SitemapBehavior::CHANGEFREQ_DAILY,
                'priority' => 0.8,
                'news' => [
                    'publication'   => [
                        'name'          => 'Example Blog',
                        'language'      => 'en',
                    ],
                    'access'            => 'Subscription',
                    'genres'            => 'Blog, UserGenerated',
                    'publication_date'  => 'YYYY-MM-DDThh:mm:ssTZD',
                    'title'             => 'Example Title',
                    'keywords'          => 'example, keywords, comma-separated',
                    'stock_tickers'     => 'NASDAQ:A, NASDAQ:B',
                ],
                'images' => [
                    [
                        'loc'           => 'http://example.com/image.jpg',
                        'caption'       => 'This is an example of a caption of an image',
                        'geo_location'  => 'City, State',
                        'title'         => 'Example image',
                        'license'       => 'http://example.com/license',
                    ],
                ],
            ],
        ],
        'enableGzip' => true, // default is false
        'cacheExpire' => 1, // 1 second. Default is 24 hours
    ],
],
  • Add behavior in the AR models, for example:
use katech91\sitemap\behaviors\SitemapBehavior;

public function behaviors()
{
    return [
        'sitemap' => [
            'class' => SitemapBehavior::className(),
            'scope' => function ($model) {
                /** @var \yii\db\ActiveQuery $model */
                $model->select(['url', 'lastmod']);
                $model->andWhere(['is_deleted' => 0]);
            },
            'dataClosure' => function ($model) {
                /** @var self $model */
                return [
                    'loc' => Url::to($model->url, true),
                    'lastmod' => strtotime($model->lastmod),
                    'changefreq' => SitemapBehavior::CHANGEFREQ_DAILY,
                    'priority' => 0.8
                ];
            }
        ],
    ];
}
  • Add a new rules for urlManager of your application's configuration file, for example:
'urlManager' => [
    'rules' => [
        ['pattern' => 'sitemap', 'route' => 'sitemap/default/sitemap-index', 'suffix' => '.xml'],
        [
            'pattern' => 'sitemap_<name:.+?><delimetr:_+><page:(\d+)>',
            'route' => 'sitemap/default/sitemap',
            'defaults' => [
                'delimetr' => null,
                'page' => null
            ],
            'suffix' => '.xml',
        ]
    ],
],
  • Sitemap creates by following scheme: sitemap.xml containes SitemapIndex with list of local sitemaps and url's sitemap:
<?xml version="1.0" encoding="UTF-8"?>
<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
               xmlns:image="http://www.google.com/schemas/sitemap-image/1.1"
               xmlns:news="http://www.google.com/schemas/sitemap-news/0.9">
    <sitemap>
        <loc>http://localhost/sitemap_urls.xml</loc>
    </sitemap>
    <sitemap>
        <loc>http://localhost/sitemap_news.xml</loc>
    </sitemap>
</sitemapindex>

local sitemaps (for example sitemap_news.xml) contains addresses of news if number of articles is less than 1 000:, (*5)

<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
        xmlns:image="http://www.google.com/schemas/sitemap-image/1.1"
        xmlns:news="http://www.google.com/schemas/sitemap-news/0.9">
    <url>
        <loc>http://localhost/news/first</loc>
        <lastmod>2016-01-01T00:00:00+00:00</lastmod>
        <changefreq>daily</changefreq>
        <priority>0.8</priority>                
    </url>
    <url>
        <loc>http://localhost/news/second</loc>
        <lastmod>2016-01-11T00:00:00+00:00</lastmod>
        <changefreq>daily</changefreq>
        <priority>0.8</priority>
        <news:news>
    </url>
    </urlset>

If number of articles bigger local sitemap contains addresses of subsitemaps: html <?xml version="1.0" encoding="UTF-8"?> <sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:image="http://www.google.com/schemas/sitemap-image/1.1" xmlns:news="http://www.google.com/schemas/sitemap-news/0.9"> <sitemap> <loc>http://localhost/sitemap_news_0.xml</loc> </sitemap> <sitemap> <loc>http://localhost/sitemap_news_1.xml</loc> </sitemap> <sitemap> <loc>http://localhost/sitemap_news_2.xml</loc> </sitemap> </sitemapindex>, (*6)

Resources

The Versions

17/10 2016

dev-master

9999999-dev

Yii2 module for automatically generation XML Sitemap

  Sources   Download

MIT

The Requires

 

xml yii2 module sitemap

16/10 2016

1.2.0

1.2.0.0

Yii2 module for automatically generation XML Sitemap

  Sources   Download

MIT

The Requires

 

xml yii2 module sitemap

31/07 2015

1.1.2

1.1.2.0

Yii2 module for automatically generation XML Sitemap

  Sources   Download

MIT

The Requires

 

xml yii2 module sitemap

26/01 2015

1.1.1

1.1.1.0

Yii2 module for automatically generation XML Sitemap

  Sources   Download

MIT

The Requires

 

xml yii2 module sitemap

29/09 2014

1.0.0

1.0.0.0

Yii2 module for automatically generation XML Sitemap

  Sources   Download

MIT

The Requires

 

xml yii2 module sitemap