The IndieWeb is a movement to decentralize the social web.
The Micropub protocol is used to create, update and delete posts on one's own domain using third-party clients. Web apps and native apps (e.g., iPhone, Android) can use Micropub to post and edit articles, short notes, comments, likes, photos, events or other kinds of posts on your own website.
— Micropub specification
You may view the full specification here. I am building this Micropub client with a few goals in mind:
- Be as spec-compliant as possible.
- Look good and support system-based dark mode.
- Make self-hosting as easy as configuring environment variables followed by
docker-compose up
. - Make IndieWeb accessible to less technically inclined folks.
- To make something useful for myself and others while I figure out and learn backend content.
If you'd like to show me some support, please star the project. ♥
Although spec compliance should ensure it works with any Micropub server, I will only be testing this with Indiekit. Paul Robert Lloyd is currently working on its successor. If you use a different Micropub server and face a problem, please open an issue and I'll see how best I can fix it.
A demo site is available through Heroku. Please note that the demo may not be the latest available version.
- Set up infrastructure with a welcome page
- IndieAuth spec compliance
- Authorization
- Complete all requirements as laid out by the spec
- Comply with changes to IndieAuth as on 2020/08/09
- Authorization
- Micropub spec compliance - being tracked here.
- General resilience tasks
- Use a logging library like
winston
- Unit testing
- Modular codebase (as many smaller & side-effects-free functions as possible without compromising readability)
- Express security checklist
- Redis security checklist
- Use a logging library like
- Polish
- Design
- Consistent spacing
- Work with page zoom as well as base font size in browser settings
- Design for more breakpoints (tablets, specifically) if the need is seen
- Forms
- Single page for article/note (title vs no-title)
- Single page for like/repost (radiobox to pick between)
- Sprinkle helpful hints throughout the app
- Design
- Rely on our own code instead of external libraries for menial tasks. Reduce dependencies and allow the project to be maintainable in the long run.
- Docker image based on
node:version-alpine
- Add an inline/split Markdown preview for supported post types.
- Full-width layout for a better and familiar publishing experience.
- Option for user to turn off helpful hints in preferences (for advanced users)
- Add experimental (non-spec) support for the following post types:
- Break IndieAuth implementation into a module
Although I do not consider this ready for public use, you are welcome to self-host.
Detailed development instructions are available.
A Docker image is available.
docker build . -t hirusi/celestial:version
- example:
docker build . -t hirusi/celestial:0.13.0
- example:
docker login
docker push hirusi/celestial:version
git push heroku master
- I have implemented a strong Content Security Policy, and only allow the browser to load images from certain specified domains. This will not be changed to accomodate your domain.
- Workaround: If you self-host, it's easy to add a new domain to the list of allowed domains. This will nicely show your profile photo (based on microformats2) once you log in. To do this, head over to the
src/index.ts
file and change the following block to include your domain:
// Set up a CSP const directives = { defaultSrc: ["'self'"], scriptSrc: ["'self'", "https://twemoji.maxcdn.com/"], imgSrc: ["'self'", "https://twemoji.maxcdn.com/", "https://yourdomain.com"], };
- Workaround: If you self-host, it's easy to add a new domain to the list of allowed domains. This will nicely show your profile photo (based on microformats2) once you log in. To do this, head over to the
- In the event the example server runs into excessive traffic, it will not scale. I have aimed to make self-hosting easy for exactly this reason. If you are facing any issue in doing so, please open an issue on the repository and someone should be able to help you.