228 lines
4.2 KiB
Markdown
228 lines
4.2 KiB
Markdown
# Mitra
|
|
|
|
Federated social network with blockchain integration.
|
|
|
|
Built on [ActivityPub](https://www.w3.org/TR/activitypub/) protocol, self-hosted, lightweight. Part of the [Fediverse](https://en.wikipedia.org/wiki/Fediverse).
|
|
|
|
Unique features:
|
|
|
|
- [Sign-in with a wallet](https://eips.ethereum.org/EIPS/eip-4361).
|
|
- Subscriptions (recurring payments). Subscribers-only posts.
|
|
- Donations.
|
|
- Token-gated registration (can be used to verify membership in some group or to stop bots).
|
|
- Converting posts into NFTs.
|
|
|
|
Supported blockchains:
|
|
|
|
- Monero.
|
|
- Ethereum and other EVM-compatible blockchains.
|
|
|
|
Demo instance: https://public.mitra.social/ ([invite-only](https://public.mitra.social/about-public))
|
|
|
|
Network stats: https://the-federation.info/mitra
|
|
|
|
Matrix chat: [#mitra:halogen.city](https://matrix.to/#/#mitra:halogen.city)
|
|
|
|
## 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
|
|
|
|
- Rust 1.54+ (when building from source)
|
|
- PostgreSQL 12+
|
|
- IPFS node (optional, see [guide](./docs/ipfs.md))
|
|
- Ethereum node (optional)
|
|
- Monero node and Monero wallet (optional)
|
|
|
|
## 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 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.
|
|
|
|
Start Mitra:
|
|
|
|
```
|
|
./mitra
|
|
```
|
|
|
|
An HTTP server will be needed to handle HTTPS requests and serve the frontend. See the example of [nginx configuration file](./contrib/mitra.nginx).
|
|
|
|
Building instructions for `mitra-web` frontend can be found at https://codeberg.org/silverpill/mitra-web#project-setup.
|
|
|
|
To run Mitra as a systemd service, check out the [systemd unit file example](./contrib/mitra.service).
|
|
|
|
### Debian package
|
|
|
|
Download and install Mitra package:
|
|
|
|
```
|
|
dpkg -i mitra.deb
|
|
```
|
|
|
|
Install PostgreSQL and create the database. 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 and serve the frontend. See the example of [nginx configuration file](./contrib/mitra.nginx).
|
|
|
|
## Development
|
|
|
|
### Create database
|
|
|
|
```
|
|
docker-compose up
|
|
```
|
|
|
|
Test connection:
|
|
|
|
```
|
|
psql -h localhost -p 55432 -U mitra mitra
|
|
```
|
|
|
|
### 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](./FEDERATION.md)
|
|
|
|
## Client API
|
|
|
|
### Mastodon API
|
|
|
|
Most methods are similar to Mastodon API, but Mitra is not fully compatible.
|
|
|
|
[OpenAPI spec](./docs/openapi.yaml) (incomplete)
|
|
|
|
## CLI
|
|
|
|
Commands must be run as the same user as the web service:
|
|
|
|
```
|
|
su mitra -c "mitractl generate-invite-code"
|
|
```
|
|
|
|
### Commands
|
|
|
|
Print help:
|
|
|
|
```shell
|
|
mitractl --help
|
|
```
|
|
|
|
Generate RSA private key:
|
|
|
|
```
|
|
mitractl generate-rsa-key
|
|
```
|
|
|
|
Generate invite code:
|
|
|
|
```
|
|
mitractl generate-invite-code
|
|
```
|
|
|
|
List generated invites:
|
|
|
|
```
|
|
mitractl list-invite-codes
|
|
```
|
|
|
|
Delete profile:
|
|
|
|
```
|
|
mitractl delete-profile 55a3005f-f293-4168-ab70-6ab09a879679
|
|
```
|
|
|
|
Delete post:
|
|
|
|
```
|
|
mitractl delete-post 55a3005f-f293-4168-ab70-6ab09a879679
|
|
```
|
|
|
|
Remove remote posts and media older than 30 days:
|
|
|
|
```
|
|
mitractl delete-extraneous-posts 30
|
|
```
|
|
|
|
Delete attachments that don't belong to any post:
|
|
|
|
```
|
|
mitractl delete-unused-attachments 5
|
|
```
|
|
|
|
Generate ethereum address:
|
|
|
|
```
|
|
mitractl generate-ethereum-address
|
|
```
|
|
|
|
Update synchronization starting block of Ethereum blockchain:
|
|
|
|
```shell
|
|
mitractl update-current-block 2000000
|
|
```
|
|
|
|
Create Monero wallet:
|
|
|
|
```shell
|
|
mitractl create-monero-wallet "mitra-wallet" "passw0rd"
|
|
```
|
|
|
|
## License
|
|
|
|
[AGPL-3.0](./LICENSE)
|
|
|
|
## Support
|
|
|
|
Monero: 8Ahza5RM4JQgtdqvpcF1U628NN5Q87eryXQad3Fy581YWTZU8o3EMbtScuioQZSkyNNEEE1Lkj2cSbG4VnVYCW5L1N4os5p
|