Federated social network
 
 
Go to file
silverpill 8a7b8cefc1 Bump version 2023-09-19 12:07:22 +00:00
.cargo Revert "Use "git" protocol to access crates.io" 2023-03-19 13:54:04 +04:00
contracts Enable contract feature detection 2022-06-30 12:20:14 +00:00
contrib Improve documentation of data retention config 2023-09-11 08:29:12 +00:00
docs Use resourceConformsTo property of proposal object to determine support for FEP-0837 2023-09-17 05:30:19 +00:00
files Add files directory, update readme 2021-11-26 22:39:54 +00:00
logo Fix Mitra custom emoji size 2023-06-19 12:57:28 +00:00
mitra-cli Bump version 2023-09-19 12:07:22 +00:00
mitra-config Bump version 2023-09-19 12:07:22 +00:00
mitra-json-signatures Bump version 2023-09-19 12:07:22 +00:00
mitra-models Bump version 2023-09-19 12:07:22 +00:00
mitra-services Bump version 2023-09-19 12:07:22 +00:00
mitra-utils Bump version 2023-09-19 12:07:22 +00:00
mitra-validators Bump version 2023-09-19 12:07:22 +00:00
scripts Add contracts to debian package 2022-06-03 20:33:46 +00:00
src Set resourceConformsTo value to "user generated content" 2023-09-18 17:49:32 +00:00
.editorconfig Create workspace and move mitractl to a separate crate 2023-01-22 20:50:28 +00:00
.env Add cargo feature for making production build 2022-05-04 22:06:12 +00:00
.gitignore Add files directory, update readme 2021-11-26 22:39:54 +00:00
CHANGELOG.md Bump version 2023-09-19 12:07:22 +00:00
CONTRIBUTING.md Fix changelog 2022-12-27 21:07:34 +00:00
Cargo.lock Bump version 2023-09-19 12:07:22 +00:00
Cargo.toml Bump version 2023-09-19 12:07:22 +00:00
FEDERATION.md Add FEP-67ff to supported FEPs 2023-09-19 06:47:55 +00:00
LICENSE Initial commit 2021-09-14 12:24:05 +00:00
README.md Mention Caddy in installation instructions 2023-09-10 20:53:28 +00:00
config.yaml.example Clarify the purpose of config.yaml.example 2023-09-09 15:14:11 +00:00
docker-compose.yaml Update monero containers 2022-12-12 22:54:48 +00:00

README.md

Mitra logo

About

Federated micro-blogging platform.

Built on ActivityPub protocol, self-hosted, lightweight. Part of the Fediverse.

Features:

  • Micro-blogging service (includes support for quote posts, custom emojis and more).
  • Mastodon API.
  • Content subscription service. Subscriptions provide a way to receive monthly payments from subscribers and to publish private content made exclusively for them.
    • Supported payment methods: Monero and ERC-20 tokens (on Ethereum and other EVM-compatible blockchains).
  • Sign-in with a wallet.
  • Donation buttons.
  • Account migrations (from one server to another). Identity can be detached from the server.
  • Federation over Tor and/or I2P.

Follow: @mitra@mitra.social

Matrix chat: #mitra:hackliberty.org

Instances

Demo instance: https://public.mitra.social/ (invite-only)

Supported clients

Code

Server: https://codeberg.org/silverpill/mitra (this repo)

Web client: https://codeberg.org/silverpill/mitra-web

Ethereum contracts: https://codeberg.org/silverpill/mitra-contracts

Requirements

  • PostgreSQL 12+
  • Rust 1.57+ (when building from source)

Minimum system requirements:

  • 256 MB RAM (1 GB for building from source)
  • 10 GB storage for average single user instance with default configuration

Optional integrations:

  • Monero wallet service and Monero node
  • Ethereum node
  • IPFS node (see guide)

Installation

Building from source

Run:

cargo build --release --features production

This command will produce two binaries in target/release directory, mitra and mitractl.

Install PostgreSQL and create the database:

CREATE USER mitra WITH PASSWORD 'mitra';
CREATE DATABASE mitra OWNER mitra;

Create configuration file by copying contrib/mitra_config.yaml and configure the instance. Default config file path is /etc/mitra/config.yaml, but it can be changed using CONFIG_PATH environment variable.

Put any static files into the directory specified in configuration file. Building instructions for mitra-web frontend can be found at https://codeberg.org/silverpill/mitra-web#project-setup.

Start Mitra:

./mitra

An HTTP server will be needed to handle HTTPS requests. See examples of Nginx and Caddy configuration files.

To run Mitra as a systemd service, check out the systemd unit file example.

Debian package

Download and install Mitra package:

dpkg -i mitra.deb

Install PostgreSQL and create the database:

CREATE USER mitra WITH PASSWORD 'mitra';
CREATE DATABASE mitra OWNER mitra;

Open configuration file /etc/mitra/config.yaml and configure the instance.

Start Mitra:

systemctl start mitra

An HTTP server will be needed to handle HTTPS requests. See examples of Nginx and Caddy configuration files.

Other installation methods

These images and packages are maintained by the community.

Docker image

https://hub.docker.com/r/bleakfuture0/mitra

Alpine Linux

Install from testing repository:

echo '@testing https://dl-cdn.alpinelinux.org/alpine/edge/testing' >> /etc/apk/repositories
apk update
apk add -vi mitra@testing

Configuration

Tor federation

See guide.

Blockchain integrations

Development

See CONTRIBUTING.md

Start database server

docker-compose up -d

Test connection:

psql -h localhost -p 55432 -U mitra mitra

Start Monero node and wallet server

(this step is optional)

docker-compose --profile monero up -d

Run web service

Create config file, adjust settings if needed:

cp config.yaml.example config.yaml

Compile and run service:

cargo run

Run CLI

cargo run --bin mitractl

Run linter

cargo clippy

Run tests

cargo test

Federation

See FEDERATION.md

Client API

Most methods are similar to Mastodon API, but Mitra is not fully compatible.

OpenAPI spec

CLI

mitractl is a command-line tool for performing instance maintenance.

Documentation

License

AGPL-3.0

Support

Monero: 8Ahza5RM4JQgtdqvpcF1U628NN5Q87eryXQad3Fy581YWTZU8o3EMbtScuioQZSkyNNEEE1Lkj2cSbG4VnVYCW5L1N4os5p