Generate sitemap.xml for Datasette sites
Project description
datasette-sitemap
Generate sitemap.xml for Datasette sites
Installation
Install this plugin in the same environment as Datasette.
datasette install datasette-sitemap
Usage
Once configured, this plugin adds a sitemap at /sitemap.xml
with a list of URLs.
This list is defined using a SQL query in metadata.json
(or .yml
) that looks like this:
{
"plugins": {
"datasette-sitemap": {
"query": "select '/' || id as path from my_table"
}
}
}
Using metadata.yml
allows for multi-line SQL queries which can be easier to maintain:
plugins:
datasette-sitemap:
query: |
select
'/' || id as path
from
my_table
The SQL query must return a column called path
. The values in this column must begin with a /
. They will be used to generate a sitemap that looks like this:
<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<url><loc>https://example.com/1</loc></url>
<url><loc>https://example.com/2</loc></url>
</urlset>
You can use UNION
in your SQL query to combine results from multiple tables, or include literal paths that you want to include in the index:
select
'/data/table1/' || id as path
from table1
union
select
'/data/table2/' || id as path
from table2
union
select
'/about' as path
If your Datasette instance has multiple databases you can configure the database to query using the database
configuration property.
By default the domain name for the genearted URLs in the sitemap will be detected from the incoming request.
You can set base_url
instead to override this. This should not include a trailing slash.
This example shows both of those settings, running the query against the content
database and setting a custom base URL:
plugins:
datasette-sitemap:
query: |
select '/plugins/' || name as path from plugins
union
select '/tools/' || name as path from tools
union
select '/news' as path
database: content
base_url: https://datasette.io
Development
To set up this plugin locally, first checkout the code. Then create a new virtual environment:
cd datasette-sitemap
python3 -m venv venv
source venv/bin/activate
Now install the dependencies and test dependencies:
pip install -e '.[test]'
To run the tests:
pytest
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file datasette-sitemap-0.1.tar.gz
.
File metadata
- Download URL: datasette-sitemap-0.1.tar.gz
- Upload date:
- Size: 7.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f705038a21251e4af6675786c7dd7cdfccc2a5204025c7c86beffafcdb94da44 |
|
MD5 | 7d32d408c6695bc7c26e03018df1fdfb |
|
BLAKE2b-256 | b0673328b801a8a28f3426bccc8bb5c7e4074a4680a06345603017092ed2598c |
File details
Details for the file datasette_sitemap-0.1-py3-none-any.whl
.
File metadata
- Download URL: datasette_sitemap-0.1-py3-none-any.whl
- Upload date:
- Size: 8.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bbc9305ab5e5feb54a0326dd547770f4077c419f46940da2cffc77c546eecd0b |
|
MD5 | 145366df1ce5bcae0317b967ee76edfe |
|
BLAKE2b-256 | a784c8c003b0a2b3901b0ff6e2342e24056031620657117b4b1539cb6f43eb45 |