A fun, new, open way to experience social media
Go to file
freeplay d06bbe7b1b fix: add back channel display in timeline 2023-07-04 13:47:31 -04:00
.config expose redis tls settings directly to config 2023-06-28 03:09:22 +01:00
.vscode vscode: replace eslint with rome 2023-01-14 14:33:15 +01:00
.woodpecker Merge remote-tracking branch 'helm/add-helm-chart' into develop 2023-05-10 16:54:26 -07:00
chart update helm config template 2023-06-28 03:10:54 +01:00
custom fix sounds settings 2023-03-29 13:38:59 -07:00
cypress chore: 🎨 format 2023-06-23 21:22:44 -07:00
dev postgres: revert to 12.2 version 2022-12-19 02:57:51 +02:00
docs docs: 📝 use document instead of symlink 2023-06-23 21:48:49 -07:00
issue_template chore: 📝 too many emojis 2023-06-23 21:27:00 -07:00
locales chore: Translated using Weblate (Chinese (Simplified)) 2023-07-04 12:29:23 +02:00
packages fix: add back channel display in timeline 2023-07-04 13:47:31 -04:00
scripts fix compile error 2023-06-24 04:07:19 -04:00
.dockerignore cache native-utils 2023-06-22 16:25:42 -04:00
.editorconfig Use tabs in json 2017-05-24 20:27:39 +09:00
.envrc Fixed dev enviroment _> documented procedure 2023-05-31 13:52:21 +02:00
.gitattributes MisskeyRoom (#5267) 2019-08-18 14:41:33 +09:00
.gitignore cache cargo artifacts 2023-06-04 17:03:47 -04:00
.node-version Update '.node-version' 2023-05-31 02:36:19 +00:00
.npmrc pnpm 8! 2023-03-26 00:37:11 -07:00
.vsls.json Add .vsls.json 2018-08-13 00:24:45 +09:00
.weblate chore: add weblate config file 2023-04-16 19:38:29 -07:00
CALCKEY.md docs: 📝 changelog 2023-06-23 20:19:25 -07:00
CHANGELOG.md docs: 📝 v14.0.0-rc3 changelog 2023-06-24 15:18:26 -07:00
CODE_OF_CONDUCT.md calckey.org 2023-05-10 23:30:48 -07:00
CONTRIBUTING.md Merge remote-tracking branch 'helm/add-helm-chart' into develop 2023-05-10 16:54:26 -07:00
COPYING Add Calckey copyright 2022-12-13 20:23:58 +01:00
Dockerfile cache native-utils 2023-06-22 16:25:42 -04:00
LICENSE Use AGPLv3 2018-03-28 22:56:28 +09:00
Procfile Create Procfile 2019-04-05 18:17:30 +09:00
README.md docs: 📝 mention libvips requirement 2023-06-24 13:23:12 -07:00
SECURITY.md minor spelling mistake 2022-12-13 17:33:50 +00:00
calckey.apache.conf Merge pull request 'docs: Add Apache2 documentation' (#10078) from warrows/calckey:main into main 2023-05-10 17:08:51 -07:00
calckey.nginx.conf docs: 📝 improve documentation, nginx 2022-11-15 20:16:50 -08:00
cliff.toml fix: Header of cliff.toml changed to automatically link to calckey.md 2023-01-04 16:36:58 +00:00
cypress.config.ts chore: 🎨 format 2023-06-23 21:22:44 -07:00
docker-compose.yml precompile rust components 2023-06-22 16:00:28 -04:00
flake.lock Fixed dev enviroment _> documented procedure 2023-05-31 13:52:21 +02:00
flake.nix Fixed dev enviroment _> documented procedure 2023-05-31 13:52:21 +02:00
gulpfile.js chore: format 2023-06-05 17:27:40 -07:00
package.json Merge branch 'develop' into beta 2023-06-24 15:12:45 -07:00
patrons.json chore: 👥 patrons 2023-07-03 22:57:03 +00:00
pnpm-lock.yaml store cache values to redis 2023-07-02 20:37:46 -04:00
pnpm-workspace.yaml use schema in native-utils 2023-06-02 23:48:24 -04:00
pull_request_template.yml chore: 🛂 conventional commits in body, not checkbox 2023-06-13 17:25:12 -07:00
release.json release notes 2023-03-14 16:55:24 -07:00
rome.json perf: update emojis, cache in IndexedDb 2023-06-22 19:34:52 -07:00
title_float.svg refactor: rm .github folder 2022-12-16 10:44:09 -08:00


Calckey logo

🌎 Calckey is an open source, decentralized social media platform that's free forever! 🚀

no github badge status badge opencollective badge liberapay badge translate-badge docker badge Contributor Covenant Codeberg badge

Calc (the Calckey mascot) smoking a fat dart

About Calckey

  • Calckey is based off of Misskey, a powerful microblogging server on ActivityPub with features such as emoji reactions, a customizable web UI, rich chatting, and much more!
  • Calckey adds many quality of life changes and bug fixes for users and server admins alike.
  • Read this document all for current and future differences.
  • Notable differences:
    • Improved UI/UX (especially on mobile)
    • Post editing
    • Content importing
    • Improved notifications
    • Improved server security
    • Improved accessibility
    • Improved threads
    • Recommended Servers timeline
    • OCR image captioning
    • New and improved Groups
    • Better intro tutorial
    • Compatibility with Mastodon clients/apps
    • Backfill user information
    • Advanced search
    • Many more user and admin settings
    • So much more!

🥂 Links

Want to get involved? Great!

  • If you have the means to, donations are a great way to keep us going.
  • If you know how to program in TypeScript, Vue, or Rust, read the contributing document.
  • If you know a non-English language, translating Calckey on Weblate help bring Calckey to more people. No technical experience needed!
  • Want to write/report about us, have any professional inquiries, or just have questions to ask? Contact us here!

🌠 Getting started

This guide will work for both starting from scratch and migrating from Misskey.

🔰 Easy installers

If you have access to a server that supports one of the sources below, I recommend you use it! Note that these methods won't allow you to migrate from Misskey without manual intervention.

Install on Ubuntu  Install on the Arch User Repository  Install Calckey with YunoHost

🛳️ Containerization

🧑‍💻 Dependencies

  • 🐢 At least NodeJS v18.16.0 (v20 recommended)
    • Install with nvm
  • 🐘 At least PostgreSQL v12 (v14 recommended)
  • 🍱 At least Redis v6 (v7 recommended)
  • Web Proxy (one of the following)
    • 🍀 Nginx (recommended)
    • 🦦 Caddy
    • 🪶 Apache
  • libvips

😗 Optional dependencies

🏗️ Build dependencies

  • 🦀 At least Rust v1.68.0
  • 🦬 C/C++ compiler & build tools
    • build-essential on Debian/Ubuntu Linux
    • base-devel on Arch Linux
  • 🐍 Python 3

👀 Get folder ready

git clone https://codeberg.org/calckey/calckey.git
cd calckey/

Note By default, you're on the develop branch. Run git checkout main or git checkout beta to switch to the Main/Beta branches.

📩 Install dependencies

# nvm install 19 && nvm use 19
corepack enable
corepack prepare pnpm@latest --activate
# To build without TensorFlow, append --no-optional
pnpm i # --no-optional


To install pm2 run:

npm i -g pm2
pm2 install pm2-logrotate

Note pm2-logrotate ensures that log files don't infinitely gather size, as Calckey produces a lot of logs.

🐘 Create database

In PostgreSQL (psql), run the following command:

CREATE DATABASE calckey WITH encoding = 'UTF8';

or run the following from the command line:

psql postgres -c "create database calckey with encoding = 'UTF8';"

In Calckey's directory, fill out the db section of .config/default.yml with the correct information, where the db key is calckey.

🦔 Sonic

Sonic is better suited for self hosters with smaller deployments. It uses almost no resources, barely any any disk space, and is relatively fast.

Follow sonic's installation guide

Note If you use IPv4: in Sonic's directory, edit the config.cfg file to change inet to "".

In Calckey's directory, fill out the sonic section of .config/default.yml with the correct information.


Meilisearch is better suited for larger deployments. It's faster but uses far more resources and disk space.

Follow Meilisearch's quick start guide

In Calckey's directory, fill out the meilisearch section of .config/default.yml with the correct information.


Please don't use ElasticSearch unless you already have an ElasticSearch setup and want to continue using it for Calckey. ElasticSearch is slow, heavy, and offers very few benefits over Sonic/Meilisearch.

💅 Customize

  • To add custom CSS for all users, edit ./custom/assets/instance.css.
  • To add static assets (such as images for the splash screen), place them in the ./custom/assets/ directory. They'll then be available on https://yourserver.tld/static-assets/filename.ext.
  • To add custom locales, place them in the ./custom/locales/ directory. If you name your custom locale the same as an existing locale, it will overwrite it. If you give it a unique name, it will be added to the list. Also make sure that the first part of the filename matches the locale you're basing it on. (Example: en-FOO.yml)
  • To add custom error images, place them in the ./custom/assets/badges directory, replacing the files already there.
  • To add custom sounds, place only mp3 files in the ./custom/assets/sounds directory.
  • To update custom assets without rebuilding, just run pnpm run gulp.

🧑‍🔬 Configuring a new server

  • Run cp .config/example.yml .config/default.yml
  • Edit .config/default.yml, making sure to fill out required fields.
  • Also copy and edit .config/docker_example.env to .config/docker.env if you're using Docker.

🚚 Migrating from Misskey to Calckey

For migrating from Misskey v13, Misskey v12, and Foundkey, read this document.

🌐 Web proxy

  • Run sudo cp ./calckey.nginx.conf /etc/nginx/sites-available/ && cd /etc/nginx/sites-available/
  • Edit calckey.nginx.conf to reflect your server properly
  • Run sudo ln -s ./calckey.nginx.conf ../sites-enabled/calckey.nginx.conf
  • Run sudo nginx -t to validate that the config is valid, then restart the NGINX service.

🦦 Caddy

  • Add the following block to your Caddyfile, replacing example.tld with your own domain:
example.tld {
  • Reload your caddy configuration

🪶 Apache

Warning Apache has some known problems with Calckey. Only use it if you have to.

  • Run sudo cp ./calckey.apache.conf /etc/apache2/sites-available/ && cd /etc/apache2/sites-available/
  • Edit calckey.apache.conf to reflect your server properly
  • Run sudo a2ensite calckey.apache to enable the site
  • Run sudo service apache2 restart to reload apache2 configuration

🚀 Build and launch!

🐢 NodeJS + pm2

git pull and run these steps to update Calckey in the future!

# git pull
pnpm install
NODE_ENV=production pnpm run build && pnpm run migrate
pm2 start "NODE_ENV=production pnpm run start" --name Calckey

😉 Tips & Tricks

  • When editing the config file, please don't fill out the settings at the bottom. They're designed only for managed hosting, not self hosting. Those settings are much better off being set in Calckey's control panel.
  • Port 3000 (used in the default config) might be already used on your server for something else. To find an open port for Calckey, run for p in {3000..4000}; do ss -tlnH | tr -s ' ' | cut -d" " -sf4 | grep -q "${p}$" || echo "${p}"; done | head -n 1. Replace 3000 with the minimum port and 4000 with the maximum port if you need it.
  • I'd recommend you use a S3 Bucket/CDN for Object Storage, especially if you use Docker.
  • I'd strongly recommend against using CloudFlare, but if you do, make sure to turn code minification off.
  • For push notifications, run npx web-push generate-vapid-keys, then put the public and private keys into Control Panel > General > ServiceWorker.
  • For translations, make a DeepL account and generate an API key, then put it into Control Panel > General > DeepL Translation.
  • To add another admin account:
    • Go to the user's page > 3 Dots > About > Moderation > turn on "Moderator"
    • Go back to Overview > click the clipboard icon next to the ID
    • Run psql -d calckey (or whatever the database name is)
    • Run UPDATE "user" SET "isAdmin" = true WHERE id='999999'; (replace 999999 with the copied ID)
    • Restart your Calckey server