166 lines
3.5 KiB
Markdown
166 lines
3.5 KiB
Markdown
# FediMovies
|
|
[![status-badge](https://ci.caric.io/api/badges/FediMovies/fedimovies/status.svg)](https://ci.caric.io/FediMovies/fedimovies)
|
|
|
|
Lively federated movies reviews platform.
|
|
|
|
Built on [ActivityPub](https://www.w3.org/TR/activitypub/) protocol, self-hosted, lightweight. Part of the [Fediverse](https://en.wikipedia.org/wiki/Fediverse).
|
|
|
|
Features:
|
|
|
|
- Micro-blogging service (includes support for quote posts, custom emojis and more).
|
|
- Mastodon API.
|
|
- Account migrations (from one server to another). Identity can be detached from the server.
|
|
- Federation over Tor.
|
|
|
|
## Instances
|
|
|
|
- [FediList](http://demo.fedilist.com/instance?software=fedimovies)
|
|
- [Fediverse Observer](https://fedimovies.fediverse.observer/list)
|
|
|
|
Demo instance: https://nullpointer.social/ ([invite-only](https://nullpointer.social/about))
|
|
|
|
## Code
|
|
|
|
Server: https://code.caric.io/reef/reef (this repo)
|
|
|
|
Web client:
|
|
|
|
|
|
## Requirements
|
|
|
|
- Rust 1.57+ (when building from source)
|
|
- PostgreSQL 12+
|
|
|
|
Optional:
|
|
|
|
- IPFS node (see [guide](./docs/ipfs.md))
|
|
|
|
## Installation
|
|
|
|
### Building from source
|
|
|
|
Run:
|
|
|
|
```shell
|
|
cargo build --release --features production
|
|
```
|
|
|
|
This command will produce two binaries in `target/release` directory, `fedimovies` and `fedimoviesctl`.
|
|
|
|
Install PostgreSQL and create the database:
|
|
|
|
```sql
|
|
CREATE USER fedimovies WITH PASSWORD 'fedimovies';
|
|
CREATE DATABASE fedimovies OWNER fedimovies;
|
|
```
|
|
|
|
Create configuration file by copying `contrib/fedimovies_config.yaml` and configure the instance. Default config file path is `/etc/fedimovies/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 `fedimovies-web` frontend can be found at https://code.caric.io/FediMovies/fedimovies#project-setup.
|
|
|
|
Start Fedimovies:
|
|
|
|
```shell
|
|
./fedimovies
|
|
```
|
|
|
|
An HTTP server will be needed to handle HTTPS requests. See the example of [nginx configuration file](./contrib/fedimovies.nginx).
|
|
|
|
To run Fedimovies as a systemd service, check out the [systemd unit file example](./contrib/fedimovies.service).
|
|
|
|
### Debian package
|
|
|
|
Download and install Fedimovies package:
|
|
|
|
```shell
|
|
dpkg -i fedimovies.deb
|
|
```
|
|
|
|
Install PostgreSQL and create the database:
|
|
|
|
```sql
|
|
CREATE USER fedimovies WITH PASSWORD 'fedimovies';
|
|
CREATE DATABASE fedimovies OWNER fedimovies;
|
|
```
|
|
|
|
Open configuration file `/etc/fedimovies/config.yaml` and configure the instance.
|
|
|
|
Start Fedimovies:
|
|
|
|
```shell
|
|
systemctl start fedimovies
|
|
```
|
|
|
|
An HTTP server will be needed to handle HTTPS requests. See the example of [nginx configuration file](./contrib/fedimovies.nginx).
|
|
|
|
### Tor federation
|
|
|
|
See [guide](./docs/onion.md).
|
|
|
|
## Development
|
|
|
|
See [CONTRIBUTING.md](./CONTRIBUTING.md)
|
|
|
|
### Start database server
|
|
|
|
```shell
|
|
docker-compose up -d
|
|
```
|
|
|
|
Test connection:
|
|
|
|
```shell
|
|
psql -h localhost -p 55432 -U fedimovies fedimovies
|
|
```
|
|
|
|
### Run web service
|
|
|
|
Create config file, adjust settings if needed:
|
|
|
|
```shell
|
|
cp config.yaml.example config.yaml
|
|
```
|
|
|
|
Compile and run service:
|
|
|
|
```shell
|
|
cargo run
|
|
```
|
|
|
|
### Run CLI
|
|
|
|
```shell
|
|
cargo run --bin fedimoviesctl
|
|
```
|
|
|
|
### Run linter
|
|
|
|
```shell
|
|
cargo clippy
|
|
```
|
|
|
|
### Run tests
|
|
|
|
```shell
|
|
cargo test
|
|
```
|
|
|
|
## Federation
|
|
|
|
See [FEDERATION.md](./FEDERATION.md)
|
|
|
|
## Client API
|
|
|
|
Most methods are similar to Mastodon API, but Fedimovies is not fully compatible.
|
|
|
|
[OpenAPI spec](./docs/openapi.yaml)
|
|
|
|
## CLI
|
|
|
|
`fedimoviesctl` is a command-line tool for performing instance maintenance.
|
|
|
|
[Documentation](./docs/fedimoviesctl.md)
|
|
|
|
## License
|
|
|
|
[AGPL-3.0](./LICENSE)
|