Clojure library for generating sitemaps.
Sitemaps XML format described on http://www.sitemaps.org/.
Sitemap library accepts Clojure list/vectore data sctructure and produces sitemap XML as string.
Optionally sitemap XML can be saved to file using provided path.
Input data structure should be in the following format:
[
{:loc "http://hashobject.com/about"
:lastmod "2013-05-31"
:changefreq "monthly"
:priority "0.8"}
{:loc "http://hashobject.com/team"
:lastmod "2013-06-01"
:changefreq "monthly"
:priority "0.9"}]
So it should be sequence of hash maps. Each map should have following keys:
- loc - url to the page
- lastmod - date when page was modified in YYYY-MM-DD format
- changefreq - how often page content will be changed (daily, weekly, monthly, never)
- priority - what is the priority of this page on the site (from 0 to 1)
Note that only 'loc' key is mandatory.
Please refer to documentation for values' formats of each key.
[sitemap "0.2.4"]
user=> (use 'sitemap.core)
nil
user=> (generate-sitemap [{:loc "http://hashobject.com/about"
:lastmod "2013-05-31"
:changefreq "monthly"
:priority "0.8"}
{:loc "http://hashobject.com/team"
:lastmod "2013-06-01"
:changefreq "monthly"
:priority "0.9"}])
generates the following XML:
<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<url>
<loc>http://hashobject.com/about</loc>
<lastmod>2013-05-31</lastmod>
<changefreq>monthly</changefreq>
<priority>0.8</priority>
</url>
<url>
<loc>http://hashobject.com/team</loc>
<lastmod>2013-06-01</lastmod>
<changefreq>monthly</changefreq>
<priority>0.9</priority>
</url>
</urlset>
We recommend you to validate your sitemap before submitting it to Google Webmaster tools. You can use this library and there are also plenty of online validators.
This library can validate the generated XML against version 0.9 of the schema.
(use 'sitemap.core)
(import 'java.io.File)
(->>
(generate-sitemap [{:loc "http://example.com/about"
:lastmod "2014-07-23"
:changefreq "monthly"
:priority "0.5"}])
(save-sitemap (File. "/tmp/sitemap.xml"))
(validate-sitemap)
(count)
(format "You have %d errors"))
; "You have 0 errors"
Validation errors are reported as a list of SAXParseException:
(->>
(generate-sitemap [{:loc "http://example.com/about"
:lastmod "2000-00-00"
:changefreq "monthly"
:priority "0.8"}])
(save-sitemap (File. "/tmp/sitemap-bad.xml"))
(validate-sitemap)
(map #(.getMessage %)))
;("cvc-datatype-valid.1.2.3: '2000-00-00' is not a valid value of union type 'lastmod'."
; "cvc-type.3.1.3: The value '2000-00-00' of element 'lastmod' is not valid.")
We love contributions. Please submit your pull requests.
Copyright © 2013-2017 Hashobject Ltd (team@hashobject.com).
Distributed under the Eclipse Public License.