An open API service indexing awesome lists of open source software.

https://github.com/rafaelcaricio/fedimovies

Federated Movies Reviews with ActivityPub.
https://github.com/rafaelcaricio/fedimovies

activitypub activitypub-server fediverse fediverse-server rust-lang

Last synced: 26 days ago
JSON representation

Federated Movies Reviews with ActivityPub.

Awesome Lists containing this project

README

        

# 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)