GithubHelp home page GithubHelp logo

sim1222 / calckey Goto Github PK

View Code? Open in Web Editor NEW
1.0 1.0 0.0 358.42 MB

License: GNU Affero General Public License v3.0

Shell 0.01% Dockerfile 0.01% Procfile 0.01% Smarty 0.04% CSS 0.14% TypeScript 48.79% JavaScript 7.72% HTML 0.02% Pug 0.35% Vue 35.66% SCSS 7.26%

calckey's Introduction

Calckey logo

๐ŸŒŽ Calckey is an open source, decentralized social media platform that's free forever! ๐Ÿš€

no github badge status 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 instance admins alike.
  • Read this document all for current and future differences.
  • Notable differences:
    • Improved UI/UX (especially on mobile)
    • Improved notifications
    • Fediverse account migration
    • Improved instance security
    • Improved accessibility
    • Recommended Instances timeline
    • OCR image captioning
    • New and improved Groups
    • Better intro tutorial
    • Many more user and admin settings
    • So much more!

๐Ÿฅ‚ Links

๐ŸŒ  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

๐Ÿ‹ Docker

How to run Calckey with Docker.

๐Ÿง‘โ€๐Ÿ’ป Dependencies

  • ๐Ÿข At least NodeJS v18.12.1 (v19 recommended)
    • Install with nvm
  • ๐Ÿ˜ At least PostgreSQL v12
  • ๐Ÿฑ At least Redis v6 (v7 recommend)

๐Ÿ˜— Optional dependencies

  • FFmpeg for video transcoding
  • ElasticSearch for full-text search
    • OpenSearch/Sonic are not supported as of right now
  • Management (choose one of the following)
    • ๐Ÿ›ฐ๏ธ pm2
    • ๐Ÿณ Docker
    • Service manager (systemd, openrc, etc)

๐Ÿ—๏ธ Build dependencies

  • ๐Ÿฆฌ C/C++ compiler & build tools
    • build-essential on Debian/Ubuntu Linux
    • base-devel on Arch Linux
  • ๐Ÿ Python 3

๐Ÿ‘€ Get folder ready

git clone --depth 1 https://codeberg.org/calckey/calckey.git
cd calckey/

By default, you're on the development branch. Run git checkout beta or git checkout main to switch to the Beta/Main 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

๐Ÿ˜ Create database

Assuming you set up PostgreSQL correctly, all you have to run is:

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

๐Ÿ’… 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://yourinstance.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 instance

  • 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.

๐Ÿ€ NGINX

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

๐Ÿš€ Build and launch!

๐Ÿข NodeJS + pm2

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

# git pull
NODE_ENV=production pnpm install && 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)
    • Have the new admin log out and log back in

calckey's People

Contributors

syuilo avatar thatonecalculator avatar greenkeeper[bot] avatar mei23 avatar ayamorisawa avatar acid-chicken avatar tamaina avatar dependabot-preview[bot] avatar dependabot[bot] avatar johann150 avatar otofune avatar pixeldesu avatar akihikodaki avatar u1-liquid avatar rinsuki avatar freeplayg avatar dependabot-support avatar ebiselutica avatar tosuke avatar ha-dai avatar nullobsi avatar futchitwo avatar l2dy avatar mfmfuyu avatar marihachi avatar hiramiya avatar kordaris avatar xianonn avatar oni-men avatar khws4v1 avatar

Stargazers

Kaori avatar

Watchers

ใ“ใ‘ใฃใก avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.