/hollo

Federated single-user microblogging software

Primary LanguageTypeScriptGNU Affero General Public License v3.0AGPL-3.0

Hollo

Official Hollo

Note

This project is still in the early stage of development. It is not ready for production use yet.

Hollo is a federated single-user microblogging software powered by Fedify. Although it is for single-user, it is designed to be federated through ActivityPub, which means that you can follow and be followed by other users from other instances, even from other software that supports ActivityPub like Mastodon, Misskey, and so on.

Hollo does not have its own web interface. Instead, it implements Mastodon-compatible APIs so that you can integrate it with the most of the existing Mastodon clients.

How to run

Docker Compose

Note

DATABASE_URL and REDIS_URL in .env will be ignored.

docker compose up -d

How to deploy

Railway

Deploy on Railway

The simplest way to deploy Hollo is Railway. Click the button above to deploy Hollo on Railway. With this template, you can get started with your own Hollo in just a few clicks.

To deploy Hollo, you need S3 or S3-compatible object storage for storing media such as images. There are many S3-compatible object storage services, including AWS S3, Cloudflare R2, MinIO, DigitalOcean Spaces, and Linode Object Storage. Once you have your object storage ready, you'll need to configure the environment variables below appropriately (see how to use the S3 client API for each service):

  • S3_REGION: The region of the S3-compatible object storage.
  • S3_BUCKET: The bucket name of the S3-compatible object storage.
  • S3_URL_BASE: The public URL base of the S3-compatible object storage.
  • S3_ENDPOINT_URL: The endpoint URL for S3-compatible object storage.
  • AWS_ACCESS_KEY_ID: The access key for S3-compatible object storage.
  • AWS_SECRET_ACCESS_KEY: The secret key for S3-compatible object storage.

Once you've set up your environment variables and Hollo is deployed on Railway, go to https://yourdomain/setup to set up your login credentials and add your profile.

Note

You need to decide on a domain name before you start setting up Hollo for the first time. This is because you can't change your domain name once Hollo is set up.

Once you've created your profile, you're ready to start enjoying Hollo. It's worth noting that Hollo doesn't have much of a web interface of its own, so you'll need to use a client app like Phanpy for now.

Docker

The official Docker images are available on GitHub Packages: ghcr.io/dahlia/hollo. Besides this image, you need to set up a PostgreSQL database, Redis, and an S3-compatible object storage for media storage. You can use the following environment variables to configure Hollo:

  • DATABASE_URL: The URL of the PostgreSQL database.
  • REDIS_URL: The URL of the Redis server.
  • HOME_URL: If present, the home page will redirect to this URL.
  • SECRET_KEY: The secret key for securing the session.
  • LOG_LEVEL: The log level for the application. debug, info, warning, error, and fatal are available.
  • BEHIND_PROXY: Set this to true if Hollo is behind a reverse proxy.
  • S3_BUCKET: The bucket name of the S3-compatible object storage.
  • S3_URL_BASE: The public URL base of the S3-compatible object storage.
  • S3_ENDPOINT_URL: The endpoint URL for S3-compatible object storage.
  • AWS_ACCESS_KEY_ID: The access key for S3-compatible object storage.
  • AWS_SECRET_ACCESS_KEY: The secret key for S3-compatible object storage.

The image exposes the port 3000, so you can run it like this:

docker run -d -p 3000:3000 \
  -e DATABASE_URL=postgres://user:password@host:port/database \
  -e REDIS_URL=redis://host:port/0 \
  -e SECRET_KEY=your-secret-key \
  -e LOG_LEVEL=info \
  -e BEHIND_PROXY=true \
  -e S3_BUCKET=your-bucket \
  -e S3_URL_BASE=https://your-bucket.s3.amazonaws.com \
  -e S3_ENDPOINT_URL=https://s3.amazonaws.com \
  -e AWS_ACCESS_KEY_ID=your-access-key \
  -e AWS_SECRET_ACCESS_KEY=your-secret-access-key \
  ghcr.io/dahlia/hollo:latest

Current features and roadmap

  • Logging in
  • Composing a post
  • Editing a post
  • Deleting a post
  • Writing a reply
  • View posts
  • Post visibility
  • Post language
  • Pinned posts
  • Mentions
  • Hashtags
  • Media attachments
  • Polls
  • Likes (favorites)
  • Shares (reblogs)
  • Editing profile
  • Deleting account
  • Public timeline
  • Local timeline
  • Lists
  • Trends
  • Search
  • Following/unfollowing accounts
  • Following/unfollowing hashtags
  • Blocking accounts
  • Blocking domains
  • Muting accounts
  • Notifications
  • Bookmarks
  • Markers
  • Featured hashtags
  • Featured accounts

Tested clients

Etymology

The name Hollo is a Korean word 홀로, which means alone or solitary in English. It is named so because it is designed to be a single-user software.