A fork of AkkomaGang/akkoma
Find a file
2023-08-06 08:05:02 +09:00
.gitea/issue_template Update '.gitea/issue_template/feat.yml' 2022-12-12 04:26:43 +00:00
.woodpecker don't release arm64 into the amd64 filename 2023-07-27 14:24:29 +01:00
benchmarks Merge branch 'benchmark-fixes' into 'develop' 2021-12-09 15:38:26 +00:00
ci CI: Use own package as base 2021-12-26 18:05:42 +01:00
config Add support for PGroonga 2023-08-04 06:27:23 +09:00
docs Add support for PGroonga 2023-08-04 06:27:23 +09:00
installation Add NoNewPrivileges to systemd service file for source installs 2023-07-22 02:40:25 -04:00
lib Support for setting PGroonga indexing options 2023-08-06 06:16:38 +09:00
priv Support for setting PGroonga indexing options 2023-08-06 06:16:38 +09:00
rel Add no_new_privs to OpenRC service files 2023-07-22 02:40:17 -04:00
restarter fix_flaky_transfer_task_test.exs (#237) 2022-11-01 14:31:29 +00:00
scripts document prometheus 2022-12-16 10:24:36 +00:00
test Update translation files 2023-07-27 13:14:05 +00:00
.buildpacks CI: Add auto-deployment via dokku. 2019-05-31 10:55:35 +02:00
.credo.exs Move Consistency.FileLocation to ./test 2020-10-13 19:57:45 +02:00
.dockerignore Exclude docker-db from the image 2023-07-31 02:54:11 +09:00
.formatter.exs .formatter.exs: Format optional migrations 2021-01-10 11:28:41 +03:00
.gitattributes Don't treat js/css as binary in git anymore 2022-12-23 18:03:14 +00:00
.gitignore Update Docker setup 2023-07-30 00:45:03 +09:00
.mailmap Add myself to .mailmap 2021-02-15 13:19:44 +03:00
AGPL-3 LICENSE → AGPL-3 2019-04-01 00:31:21 +02:00
CC-BY-4.0 Add a copy of CC-BY-4.0 to the repo 2020-09-06 11:38:38 +03:00
CC-BY-SA-4.0 CC-BY-SA-4.0: Add a copy of the CC-BY-SA-4.0 license 2019-04-01 00:30:21 +02:00
CHANGELOG.md Changelog 2023-07-27 14:41:18 +01:00
CODE_OF_CONDUCT.md add code of conduct (#129) 2022-08-03 10:55:11 +00:00
COPYING Remove reference to city.jpg in COPYING 2022-11-25 07:29:50 +00:00
coveralls.json exclude file_location check from coveralls 2020-10-13 16:44:01 +03:00
docker-compose.yml Add support for PGroonga 2023-08-04 06:27:23 +09:00
docker-entrypoint.sh Run automatic migration on startup command only 2023-08-06 04:39:35 +09:00
Dockerfile Set AKKOMA_CONFIG_PATH in Dockerfile 2023-08-05 06:09:28 +09:00
elixir_buildpack.config Update elixir version in elixir_buildpack.config 2023-03-16 12:54:15 -04:00
mix.exs Use OS CA store for Mint HTTP connections 2023-06-26 15:50:49 +02:00
mix.lock Update dependencies 2023-05-08 16:29:25 +01:00
Procfile CI: Add auto-deployment via dokku. 2019-05-31 10:55:35 +02:00
README.md Fix grammar 2023-08-06 08:05:02 +09:00
SECURITY.md SECURITY.md: update supported versions to only 2.2 2020-10-15 21:45:31 +03:00
SIGNING_KEY.pub 2022.09 stable release chores (#206) 2022-09-10 14:44:17 +00:00

What is this?

This is a fork of AkkomaGang/akkoma, with some opinionated changes to satisfy my needs.

The main differences between this and the upstream repository are

  • Uses the official Elixir image from Docker Hub
  • Automatically builds the Akkoma backend when building the Docker image, instead of requiring complex commands after pulling/building images
  • Files/directories to mount are minified and completely separated from the repository files, allowing better control over file permissions
  • Has an actual Docker entry point, rather than a command that pretends to be an entry point
  • Includes out-of-the-box support for PGroonga, the fast and accurate full-text search extension for PostgreSQL
  • Supports Podman quite well

How to setup (Podman Rootless)

You don't need to replicate backslashes followed by line breaks. They mean "Ignore the next line break" and are only used for better readability. a \<line break> b \<line break> c is the same as a b c.

0. Requirements

  • A decent CPU
  • 2GB of memory (200MB runtime)
  • 500MB free disk space
  • Podman runs as non-root user

1. Build your image

This will take 5+ minutes.

cd /YOUR/GIT/DIRECTORY/akkoma/
podman build -t akkoma .

2. Create a Podman Pod for Akkoma

podman pod create \
  --publish YOUR_PORT:4000 \
  akkoma

You can use pasta(1) if you want to preserve incoming IPs and easily access the host machine through the network gateway.

podman pod create \
  --network pasta:--map-gw,-a,10.0.2.0,-n,24,-g,10.0.2.1 \
  --add-host gateway:10.0.2.1 \
  --publish YOUR_PORT:4000 \
  akkoma

3. Setting up the database

podman run -d \
  --pod akkoma \
  --restart unless-stopped \
  --name akkoma-db \
  -e POSTGRES_DB=YOUR_DB_NAME \
  -e POSTGRES_USER=YOUR_DB_USER \
  -e POSTGRES_PASSWORD=YOUR_DB_PASS \
  -v ${PWD}/docker-db/:/var/lib/postgresql/data/:Z \
  postgres:14-alpine

If you want to use PGroonga, run the command below instead.

podman run -d \
  --pod akkoma \
  --restart unless-stopped \
  --name akkoma-db \
  -e POSTGRES_DB=YOUR_DB_NAME \
  -e POSTGRES_USER=YOUR_DB_USER \
  -e POSTGRES_PASSWORD=YOUR_DB_PASS \
  -v ${PWD}/docker-db/:/var/lib/postgresql/data/:Z \
  groonga/pgroonga:3.1.1-alpine-14

4. Setting up the backend

podman run -d \
  --pod akkoma-pod \
  --restart unless-stopped \
  --name akkoma-web \
  -e DB_NAME=YOUR_DB_NAME \
  -e DB_USER=YOUR_DB_USER \
  -e DB_PASS=YOUR_DB_PASS \
  -v ${PWD}/static/:/var/lib/akkoma/static/:Z \
  -v ${PWD}/uploads/:/var/lib/akkoma/uploads/:Z \
  -v ${PWD}/etc/:/etc/akkoma/:Z \
  akkoma

podman exec -it akkoma-web \
  pleroma_ctl \
  instance gen \
  --output /etc/akkoma/config.exs

A few notes on setup

  • Make sure your database hostname is set correctly (e.g. localhost)
  • Make sure your database password is also set correctly (don't leave it auto-generated)
  • You should set the IP to listen on to 0.0.0.0

4.1. Apply the optional PGroonga migration

Make sure you apply the migration before the first restart of the container, otherwise you will be stuck in a loop of restarts.

To apply the migration after the first restart, please refer to the guide down below.

podman exec -it akkoma-web \
  pleroma_ctl \
  migrate \
  --migrations-path priv/repo/optional_migrations/pgroonga

You can revert the applied changes at any time by replacing migrate with rollback.

5. Test your setup

podman restart akkoma-web
curl -I http://localhost:YOUR_PORT/

You should see HTTP/1.1 200 OK.

6. Setting up the frontend

podman exec -it akkoma-web \
  pleroma_ctl \
  frontend install \
  pleroma-fe
podman exec -it akkoma-web \
  pleroma_ctl \
  frontend install \
  admin-fe

7. Create your first user

podman exec -it akkoma-web \
  pleroma_ctl \
  user new \
  YOUR_NAME \
  YOUR@EMAIL.EXAMPLE \
  --admin

Follow the printed link to set your password.

8. Optional steps

Switch to PGroonga

Before moving forward, make sure you have stopped the backend for safety.

podman stop akkoma-web

After stopping the backend, change config :pleroma, :database, pgroonga_enabled to true.

config :pleroma, :database,
  rum_enabled: false,
  pgroonga_enabled: true # set this option to true

If you have command history enabled in your shell, all you need to do is remove the --name NAME option and add pleroma_ctl migrate --migrations-path priv/repo/optional_migrations/pgroonga to the end of the command.

podman run -d \
  --pod akkoma-pod \
  --restart unless-stopped \ # this option is optional (bruh)
  # --name akkoma-web \ # make sure to remove this option to avoid name conflict
  -e DB_NAME=YOUR_DB_NAME \
  -e DB_USER=YOUR_DB_USER \
  -e DB_PASS=YOUR_DB_PASS \
  -v ${PWD}/static/:/var/lib/akkoma/static/:Z \
  -v ${PWD}/uploads/:/var/lib/akkoma/uploads/:Z \
  -v ${PWD}/etc/:/etc/akkoma/:Z \
  akkoma \
  pleroma_ctl \
  migrate \
  --migrations-path priv/repo/optional_migrations/pgroonga

You can revert the applied changes anytime by replacing migrate with rollback.

Don't forget to start the container you stopped at the beginning of this guide.

podman start akkoma-web

Akkoma

a smallish microblogging platform, aka the cooler pleroma

English OK 日本語OK

About

This is a fork of Pleroma, which is a microblogging server software that can federate (= exchange messages with) other servers that support ActivityPub. What that means is that you can host a server for yourself or your friends and stay in control of your online identity, but still exchange messages with people on larger servers. Akkoma will federate with all servers that implement ActivityPub, like Friendica, GNU Social, Hubzilla, Mastodon, Misskey, Peertube, and Pixelfed.

Akkoma is written in Elixir and uses PostgreSQL for data storage.

For clients it supports the Mastodon client API with Pleroma extensions (see the API section on https://docs.akkoma.dev/stable/).

Differences with Pleroma

Akkoma is a faster-paced fork, it has a varied and potentially experimental feature set tailored specifically to the corner of the fediverse inhabited by the project creator and contributors.

This should not be considered a one-for-one match with pleroma; it is more opinionated in many ways, and has a smaller community (which is good or bad depending on your view)

For example, Akkoma has:

  • Custom Emoji reactions (compatible with misskey)
  • Misskey-flavoured markdown support
  • Elasticsearch and Meilisearch support for search
  • Mastodon frontend (Glitch-Soc and Fedibird flavours) support
  • Automatic post translation via DeepL or LibreTranslate
  • A multitude of heavy modifications to the Pleroma Frontend (Pleroma-FE)
  • The "bubble" concept, in which instance administrators can choose closely-related instances to make a "community of communities", so to say

And takes a more opinionated stance on issues like Domain blocks, which are enforced far more on Akkoma.

Take a look at the Changelog if you want a full list of recent changes, everything since 3.0 has been Akkoma.

Installation

If you are running Linux (glibc or musl) on x86, the recommended way to install Akkoma is by using OTP releases. OTP releases are as close as you can get to binary releases with Erlang/Elixir. The release is self-contained, and provides everything needed to boot it. The installation instructions are available here.

From Source

If your platform is not supported, or you just want to be able to edit the source code easily, you may install Akkoma from source.

Docker

Docker installation is supported via this setup

Packages

Akkoma is packaged for YunoHost and can be found and installed from the YunoHost app catalogue.

Compilation Troubleshooting

If you ever encounter compilation issues during the updating of Akkoma, you can try these commands and see if they fix things:

  • mix deps.clean --all
  • mix local.rebar
  • mix local.hex
  • rm -r _build

Documentation