Indiekit

 Indiekit  (GitHub repo) is “the little Node.js server with all the pieces needed to own your content and share it with the wider independent web”. This project is currently being developed by.

The immediate goal of this project was to provide a self-hosted Micropub endpoint that could save posts to a content store (such as GitHub) for subsequent publishing with a static site generator (such as Jekyll).

With that goal met, the longer term ambition is to support other publishing APIs (Webmention, Microsub, ActivityPub etc.), integrate with a wider range of content management systems, and provide a compelling web management interface.



Requirements

 * Node.js v18+

A MongoDB database is optional, but required for many features to work.

Features

 * Plug-in API with a number of first-party plug-ins to support common integrations
 * Accessible web interface
 * Localisable, with localisations provided for:
 * US English
 * Deutsch
 * Español
 * Français
 * bahasa Indonesia
 * Nederlands
 * Polski
 * Português
 * Srpski

Micropub

 * Publish content using apps and services that support the Micropub API
 * Create, update, delete and undelete posts
 * Upload files via the media endpoint
 * Configure where different post types get published
 * Publication presets to support popular static site generators and document formats
 * First-party plug-ins that support saving content to:
 * Bitbucket
 * File system
 * FTP
 * GitHub
 * GitLab
 * Gitea
 * First-party publication preset plug-ins for:
 * Jekyll
 * Hugo

Syndication

 * Syndicate content to third-party websites
 * First-party plug-ins that support syndicating to:
 * Twitter
 * Mastodon servers
 * Internet Archive

People using it

 * has been using Indiekit to post notes and photos since early 2019.
 * Robert van Bregt is trying to get Indiekit to work with his Hugo based site since November 2019.
 * has been using the project for her website since August 2020.
 * Jon Roobottom has been using Indiekit to publish photos on his website since November 2021.