The little Node.js server with all the parts needed to publish content to your personal website and share it on social networks. https://getindiekit.com
  • JavaScript 83.1%
  • Nunjucks 11.1%
  • CSS 5.7%
Find a file
Ricardo Mendes 2b87d60107 chore(preset-eleventy): update fork with permalink enhancements
- Handle full URLs by extracting pathname
- Custom URL paths for content collection
- Bump version to 1.0.0-beta.28

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-31 13:55:46 +01:00
.github chore(deps): bump github/codeql-action from 3 to 4 2026-01-02 18:17:59 +00:00
.husky chore: migrate to husky v9 2024-04-23 22:58:23 +01:00
docs chore: update sponsors 2025-12-24 19:39:09 +00:00
helpers fix(syndicator-bluesky): handle empty content in post. fixes #790 2025-12-24 11:27:38 +00:00
packages chore(preset-eleventy): update fork with permalink enhancements 2026-01-31 13:55:46 +01:00
types/express chore: add type checking in jsdoc 2023-05-26 23:28:39 +01:00
.commitlintrc.json style: use prettier 2022-02-10 23:21:57 +00:00
.editorconfig style: always remove final new line for locale files 2025-12-24 19:48:28 +00:00
.gitignore chore: ignore .envrc 2024-06-08 17:11:49 +01:00
.lintstagedrc.json style: format json files with prettier 2023-07-09 00:27:37 +01:00
.nvmrc chore: use node 22 2024-08-22 18:05:30 +01:00
.prettierignore chore: update lerna dependency 2025-12-05 23:54:09 +00:00
.stylelintrc.json ci: ignore built _site folder when linting 2023-07-16 16:35:32 +01:00
CHANGELOG.md v1.0.0-beta.26 2026-01-02 18:48:06 +00:00
eslint.config.js chore: update dependencies 2025-03-29 18:57:02 +00:00
indiekit.config.js feat(syndicator-bluesky): bluesky syndicator 2025-04-13 21:24:50 +01:00
jsconfig.json chore: update compiler target in jsconfig 2025-12-05 23:22:40 +00:00
lerna.json v1.0.0-beta.26 2026-01-02 18:48:06 +00:00
LICENSE feat: file cache service 2020-05-19 19:00:29 +01:00
localazy.json feat(endpoint-webmention-io): webmention.io endpoint 2024-12-25 22:42:05 +00:00
package-lock.json chore(preset-eleventy): update fork with permalink enhancements 2026-01-31 13:55:46 +01:00
package.json chore: add publish workflow 2025-12-24 21:46:02 +00:00
README.md docs: update readme 2025-12-24 21:53:41 +00:00

Indiekit

Indiekit logo.

Build status

Meet Indiekit, the little Node.js server with all the pieces needed to share your content with the open, independent web.

Indiekit’s application management interface.

Sponsors

Indiekit is supported by its community. Special thanks to:

Kevin Yank

Features

  • Publish content to your website using apps and services that support the Micropub API
  • Save files to a content store such as GitHub, an FTP server or S3 object storage
  • Integrate with static site generators like Eleventy, Hugo or Jekyll
  • Share content on social networks like Bluesky and Mastodon
  • Customise everything from the interface theme to the format of commit messages

Indiekit is extensible via its plug-in API and localized for use in a growing number of languages.

Requirements

  • Your own website, published using a static site generator
  • Node.js v20+

A MongoDB database is optional, but required for the following features to work:

  • Viewing, editing, deleting and restoring previously published posts
  • Syndicating posts
  • Viewing and deleting previously uploaded media files

Note

This project is known to work with MongoDB v4.4 or later. It may also work with the last openly licenced version, v4.0.3, but this has not been tested.

Get started

Learn how to set up an Indiekit server and view an example server configuration.

Documentation website

The documentation website is generated using VitePress. To view this site locally:

  1. Install this projects dependencies: npm install
  2. Start the Vite server: npm run docs:dev
  3. View the documentation: http://127.0.0.1:5173

The browser will refresh to reflect any changes you make to the documentation.

Decisions

Architectural decisions made on this project are documented using Architecture Decision Records, as described by Michael Nygard. These can be found in /docs/decisions.

Releasing

Lerna is used to manage and publish packages from this monorepo via a trusted publishing workflow.

Contributing

Read about the different ways you can contribute to this project.

Credits

Developed by Paul Robert Lloyd.

Thank-you to Aron Carroll for mentoring me during the early development of this project. Indiekit is a better project for his feedback and advice.

Similar projects

Indiekit is inspired by similar projects made by members of the IndieWeb community: