Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Pelican plugin to improve SEO (Search Engine Optimization) to reach top positions on search engines.
This plugin helps you improve your Pelican site SEO (Search Engine Optimization) to reach the top positions on search engines. To see what this SEO plugin can do for you, visit the Usage section.
Author | GitHub |
---|---|
Maëva Brunelles | https://github.com/MaevaBrunelles |
If:
… then this plugin is for you!
SEO comes with two features to help you:
This plugin can be installed via:
python -m pip install pelican-seo
The above installation step should automatically install Beautiful Soup 4, which the SEO plugin requires. The following command will manually install this dependency:
python -m pip install beautifulsoup4
Please keep in mind that the SITEURL
Pelican setting must be defined in order for this plugin to function as intended.
You can enable/disable parents features by setting them to True
or False
in your Pelican settings. The default is True
for both.
# settings.py
SEO_REPORT = True # To enable this feature
SEO_ENHANCER = False # To disable this feature
SEO_ENHANCER_OPEN_GRAPH = False # The default value for this feature
SEO_ENHANCER_TWITTER_CARDS = False # The default value for this feature
Open Graph and Twitter Cards options are part of the SEO enhancer feature, and may be enabled to generate social tags. Please note that :
SEO_ENHANCER
setting must be enabled in order to use this featureSEO_ENHANCER_OPEN_GRAPH
setting must be enabled in order to use SEO_ENHANCER_TWITTER_CARDS
(see whyThe SEO plugin runs when you generate your site. If you want to see SEO logging in your console output, add the --verbose
option to your pelican
invocation:
$ pelican content --verbose
-> SEO plugin initialized
-> SEO plugin - SEO Report: seo_report.html file created
-> SEO plugin - SEO Enhancement: robots.txt file created
-> Writing /output/my-first-review.html
-> SEO plugin - SEO Enhancement: Done for /output/my-first-review.html
Done: Processed 1 articles, 0 drafts, 0 pages, 0 hidden pages and 0 draft pages in 0.17 seconds.
The SEO plugin analyzes all your articles and pages and generate an SEO HTML report in your Pelican project root: seo-report.html
Example:
You can set limits for article and page analysis in the plugin settings.py. By default, it's set up to 10 articles and 10 pages.
SEO_ARTICLES_LIMIT = 10
SEO_PAGES_LIMIT = 10
The SEO analysis begins with the most recent articles/pages, according to the date
metadata, and is focused on the following criteria:
<title></title>
<meta name="description" content="" />
<h1></h1>
<a href="SITEURL/..."></a>
The above information is defined in your source content, such as the following example Markdown file:
Title: Page Title
Description: Page Description
# Heading Content
[Internal link](https://example.com/about.html)
Once the SEO analysis has generated a report, optimize your articles and pages according to the report’s recommendations, and then repeat the analysis to see whether everything comes up green.
The SEO Enhancer module generates the following for you:
The generated robots.txt
file indicates to search engines which pages they should index. By default, search engine bots are allowed to crawl and index all pages.
User-agent: *
To disallow crawling and/or forbid indexing for a given article/page, add the following to your article/page metadata:
Disallow: True
Noindex: True
A robots.txt
file will be generated at your web site root, as per the OUTPUT_PATH
setting (Pelican’s default is output/
).
# robots.txt
User-agent: *
Disallow: example.html
Noindex: other-example.html
The SEO Enhancer automatically adds canonical link metadata to <head>
tags in order to avoid presenting duplicate content to search engines:
:external_canonical:
metadata field, the SEO Enhancer will use it. It expects a URL, e.g. https://www.example.com/external_canonical_article.html
. It can be used if you syndicate content from third parties or want to include your own posts that are already hosted elsewhere. The SEO Enhancer will prefer :external_canonical:
over the :save_as:
metadata field.:save_as:
metadata field, the SEO Enhancer will use it to construct a canonical link. However if the :external_canonical:
is set, the :save_as:
field will be ignored.:external_canonical:
or :save_as:
metadata fields are absent, it will construct the canonical link using the output filename created.Example:
# article.md
External_Canonical: https://www.example.com/external_canonical_article.html
# article.rst
:external_canonical: https://www.example.com/external_canonical_article.html
will result in the following addition to <head>
tags:
<link rel="canonical" href="https://www.example.com/external_canonical_article.html" />
In all other cases the SEO Enhancer will generate the following:
<link rel="canonical" href="<SITEURL>/example.html" />
The SEO Enhancer automatically adds structured data in the <head>
tag in order to improve the display of result snippets in search engines. Articles will have both article schema and breadcrumb schema, while pages will only have breadcrumb schema.
Structured data is based on Schema.org vocabulary, with JSON-LD
encoding. Note that schemas generated by default are compliant with Schema.org but not (by default) Google-compliant. The latter requires additional metadata.
Based on BreadcrumbList schema:
{
"@context": "https://schema.org",
"@type": "BreadcrumbList",
"itemListElement": [
{
"@type": "ListItem",
"position": :n=1:,
"name": :Sitename:,
"item": :SITEURL:
},
{
"@type": "ListItem",
"position": :n+1:,
"name": :name:,
"item": :url:
},
{
"@type": "ListItem",
"position": :n+x:,
"name": :name:,
"item": :url:
}
]
}
Each path element has a ListItem
, even folders, so it’s better to create a user-friendly page for those (otherwise you’ll get your server’s default page).
Based on Article schema:
{
"@context": "https://schema.org",
"@type": "Article",
"author": {
"@type": "Person",
"name": :author:
},
"publisher": {
"@type": "Organization",
"name": :sitename:,
"logo": {
"@type": "ImageObject",
"url": :logo:
}
},
"headline": :title:,
"about": :category:,
"datePublished": :publication_date:,
"image": :image:
}
:logo:
and :image:
fields are not required by Schema.org but are by Google.
To populate the :logo:
field, add a LOGO
setting to your Pelican settings file containing an absolute link to your site logo image:
# pelicanconf.py
LOGO = "https://www.example.com/logo.jpg"
To populate the :image:
field, add an image metadata field to your Markdown/reST content:
# article.md
Image: https://www.example.com/article-image.jpg
# article.rst
:image: https://www.example.com/article-image.jpg
Based on Open Graph protocol, the SEO plugin implements required properties and some aditionnals ones:
<meta property="og:url" content=":fileurl:" />
:fileurl:
: An absolute URL build with the SITEURL
setting and the file URL.
<meta property="og:type" content=":type:" />
:type:
: Either article
or page
.
<meta property="og:title" content=":title:" />
<meta property="og:description" content=":description:" />
<meta property="og:image" content=":image:" />
:title:
, :description:
, :image:
: If you need to optimize your social links, you can write dedicated Open Graph content as described below in the file metadata:
og_title: Specific title for Open Graph
og_description: Specific description
og_image: https://www.example.com/og-image.jpg
If these metadata are not declared, :title:
, :description:
, :image:
will be filled by the default Title
, Description
(Pelican metadata) and Image
(plugin metadata) if they exist.
<meta property="og:locale" content=":language:">
:language:
: The site language as defined in LOCALE
Pelican setting. If not filled, it will try to get the default system locale.
The Twitter Cards feature requires Open Graph feature to be functional. To avoid the duplication of similar tags, Twitter falls back on some Open Graph tags if Twitter's are not present.
Based on Twitter guide, the SEO plugin implements the Summary Card:
<meta name="twitter:card" content="summary" />
<meta name="twitter:site" content=":tw_account:" />
:tw_account:
: The Twitter @account to link to the card. You can fill in the file metadata, but it's not a required property.
The other properties required by Twitter are created thanks to Open Graph feature.
Contributions are welcome and much appreciated. Every little bit helps. You can contribute by improving the documentation, adding missing features, and fixing bugs. You can also help out by reviewing and commenting on existing issues.
To start contributing to this plugin, review the Contributing to Pelican documentation, beginning with the Contributing Code section.
FAQs
Pelican plugin to improve SEO (Search Engine Optimization) to reach top positions on search engines.
We found that pelican-seo demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.