2017 © Pedro Peláez
 

library cartographer

A PHP sitemap generation tool.

image

gsouf/cartographer

A PHP sitemap generation tool.

  • Thursday, November 9, 2017
  • by sneakyBobito
  • Repository
  • 1 Watchers
  • 0 Stars
  • 14 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 21 Forks
  • 0 Open issues
  • 8 Versions
  • 0 % Grown

The README.md

Cartographer

Latest Stable Version Total Downloads License, (*1)

Build Status Code Coverage Scrutinizer Code Quality, (*2)


Note : This is a fork of the original work that adds support for google image extension., (*3)


A sitemap generation tool for PHP following the Sitemap Protocol v0.9., (*4)

Cartographer can handle Sitemaps of any size. When generating sitemaps with more than 50,000 entries (the limit), the sitemap becomes a "map of maps" (i.e. nested sitemaps)., (*5)

Supported PHP/HHVM Versions

  • PHP: >= 5.4 (including 5.6 beta1)
  • HHVM: >= 3.0.0

Installation

Composer CLI

composer require tackk/cartographer:1.0.*

composer.json

``` json { "require": { "tackk/cartographer": "1.0.*" } }, (*6)


## Basic Sitemap If you have a sitemap that is under 50,000 items, you can just use the Sitemap class, and avoid the Sitemap Generator. ``` php use Tackk\Cartographer\Sitemap; use Tackk\Cartographer\ChangeFrequency; $sitemap = new Tackk\Cartographer\Sitemap(); $sitemap->add('http://foo.com', '2005-01-02', ChangeFrequency::WEEKLY, 1.0); $sitemap->add('http://foo.com/about', '2005-01-01'); // Write it to a file file_put_contents('sitemap.xml', (string) $sitemap); // or simply echo it: header ('Content-Type:text/xml'); echo $sitemap->toString();

Output

``` xml http://foo.com 2005-01-02T00:00:00+00:00 weekly 1 http://foo.com/about 2005-01-01T00:00:00+00:00 , (*7)


## Basic Sitemap Index If you want to build a Sitemap Index, separate from the Sitemap Generator, you can! ``` php $sitemapIndex = new Tackk\Cartographer\SitemapIndex(); $sitemapIndex->add('http://foo.com/sitemaps/sitemap.1.xml', '2012-01-02'); $sitemapIndex->add('http://foo.com/sitemaps/sitemap.2.xml', '2012-01-02'); // Write it to a file file_put_contents('sitemap.xml', (string) $sitemapIndex); // or simply echo it: header ('Content-Type:text/xml'); echo $sitemapIndex->toString();

Output

``` xml http://foo.com/sitemaps/sitemap.1.xml 2012-01-02T00:00:00+00:00 http://foo.com/sitemaps/sitemap.2.xml 2012-01-02T00:00:00+00:00 , (*8)


## Sitemap Factory The Sitemap Factory create Sitemaps and Sitemap Indexes and writes them to the Filesystem. Is is can be used to generate full Sitemaps with more than **50,000** URLs. If more than one sitemap is generated, it will create a Sitemap Index automatically. ### Instantiating The factory uses [Flysystem](http://flysystem.thephpleague.com/) to write the sitemaps. This means you can write the sitemaps to Local Disk, S3, Dropbox, wherever you want. ``` php <?php use League\Flysystem\Filesystem; use League\Flysystem\Adapter\Local as LocalAdapter; $adapter = new LocalAdapter(__DIR__.'/sitemaps'); $filesystem = new Filesystem($adapter); $sitemapFactory = new Tackk\Cartographer\SitemapFactory($filesystem);

Base URL

The Base URL is used when generating the Sitemap Indexes, and for the returned entry point URL., (*9)

You can set the Base URL:, (*10)

``` php $sitemapFactory->setBaseUrl('http://foo.com/sitemaps/');, (*11)


You can get the current base URL using `getBaseUrl()`. ### Creating a Sitemap To create a sitemap you use the `createSitemap` method. This method requires an `Iterator` as its only parameter. ``` php <?php use League\Flysystem\Filesystem; use League\Flysystem\Adapter\Local as LocalAdapter; $adapter = new LocalAdapter(__DIR__.'/sitemaps'); $filesystem = new Filesystem($adapter); $sitemapFactory = new Tackk\Cartographer\SitemapFactory($filesystem); // Create an Iterator of your URLs somehow. $urls = get_url_iterator(); // Returns the URL to the main Sitemap/Index file $mainSitemap = $sitemapFactory->createSitemap($urls);

Google image extension

With simple sitemap:, (*12)

<?php

use Tackk\Cartographer\GoogleSitemap;
use Tackk\Cartographer\ChangeFrequency;

$sitemap = new Tackk\Cartographer\GoogleSitemap();
$sitemap->add('http://foo.com', '2005-01-02', ChangeFrequency::WEEKLY, 1.0);
// Adds an image for the previous url
$sitemap->addImage('http://foo.com/bar.jpg', 'image title', 'image caption', 'geo location', 'license');

// Write it to a file
file_put_contents('sitemap.xml', (string) $sitemap);

With sitemap factory the iterator should return an array of url that also contains an 'images' key with all images of the url., (*13)

<?php

use League\Flysystem\Filesystem;
use League\Flysystem\Adapter\Local as LocalAdapter;

$adapter = new LocalAdapter(__DIR__.'/sitemaps');
$filesystem = new Filesystem($adapter);
$sitemapFactory = new Tackk\Cartographer\GoogleSitemapFactory($filesystem);

// Create an Iterator of your URLs somehow.
$urls = get_url_iterator();

// Url iterator items format:
// ['url' => 'http://foo.com', 'images' => [
//    ['loc' => 'http://foo.com/bar.jpg']
// ]

// Returns the URL to the main Sitemap/Index file
$mainSitemap = $sitemapFactory->createSitemap($urls);

Return Value

The two creation methods (createSitemap and createSitemapIndex) will return the URL of the root sitemap file. If there is only 1 sitemap created, it will return just that URL. If multiple sitemaps are created, then a Sitemap Index is generated and the URL to that is returned., (*14)

List of Created Files

You can get a list (array) of files the Factory has created by using the getFilesCreated method., (*15)

``` php $files = $sitemapFactory->getFilesCreated();, (*16)


## Running Tests *This assumes you have ran `composer update`.* From the repository root, run:

vendor/bin/phpunit ```, (*17)

The Versions

09/11 2017

dev-master

9999999-dev

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

generator sitemap

09/11 2017

1.2.2

1.2.2.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

generator sitemap

11/09 2017

1.2.1

1.2.1.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

generator sitemap

04/09 2017

1.2.0

1.2.0.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

generator sitemap

01/05 2015

1.1.0

1.1.0.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

generator sitemap

03/05 2014

1.0.2

1.0.2.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

02/05 2014

1.0.1

1.0.1.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires

02/05 2014

1.0.0

1.0.0.0

A PHP sitemap generation tool.

  Sources   Download

MIT

The Requires

 

The Development Requires