Ingen beskrivning

default e58eb068fb Minor URL formatting tweaks. 2 år sedan
doc eb22dc5f01 Updated documentation. 2 år sedan
examples e58eb068fb Minor URL formatting tweaks. 2 år sedan
.gitignore 0cdd193be9 [.gitignore] new file. 2 år sedan
Dockerfile 89f6924ae2 Improve Docker image generation 2 år sedan
LICENSE 06c838b523 Updated LICENSE. 2 år sedan
Makefile 631f16aea8 Updated dependencies. 2 år sedan
README.md 4afa513dce Add docker-compose support, so a working development server with HTTPS can be started with: 2 år sedan
RELEASE_NOTES.md c37dd39da2 Updated RELEASE_NOTES. 2 år sedan
TODO.md 964b11e197 Updated TODO. 2 år sedan
activitypub.c 1d0ab9c156 Added (partial) support for #HashTags in posts. 2 år sedan
data.c bb0d8f2a27 Backport from xs. 2 år sedan
docker-compose.yaml 4afa513dce Add docker-compose support, so a working development server with HTTPS can be started with: 2 år sedan
format.c e58eb068fb Minor URL formatting tweaks. 2 år sedan
html.c bb0d8f2a27 Backport from xs. 2 år sedan
http.c bb0d8f2a27 Backport from xs. 2 år sedan
httpd.c bb0d8f2a27 Backport from xs. 2 år sedan
main.c 75f8554e38 Deleted unused arguments in timeline_add(). 2 år sedan
snac.c 645e7ec43e Some code reordering to placate scan-build's wrath. 2 år sedan
snac.h 40b3f739d2 Deleted unused argument in timeline_admire(). 2 år sedan
upgrade.c 67a81a7bf9 Upgrade timeline/ to private/. 2 år sedan
utils.c bb0d8f2a27 Backport from xs. 2 år sedan
webfinger.c bb0d8f2a27 Backport from xs. 2 år sedan
xs.h bb0d8f2a27 Backport from xs. 2 år sedan
xs_curl.h bb0d8f2a27 Backport from xs. 2 år sedan
xs_encdec.h fa870ab358 Backport from xs. 2 år sedan
xs_glob.h da7e57f4cc Backport from xs. 2 år sedan
xs_httpd.h bb0d8f2a27 Backport from xs. 2 år sedan
xs_io.h 1b73c542a9 Backport from xs. 2 år sedan
xs_json.h fa870ab358 Backport from xs. 2 år sedan
xs_mime.h 0f4779e2a0 Backport from xs. 2 år sedan
xs_openssl.h fa870ab358 Backport from xs. 2 år sedan
xs_regex.h f2528c6c52 Backport from xs. 2 år sedan
xs_set.h f209c3205d Use xs_set in recipient_list() and inbox_list(). 2 år sedan
xs_socket.h 0f4779e2a0 Backport from xs. 2 år sedan
xs_time.h ae06064e4d New command-line option purge. 2 år sedan
xs_version.h bb0d8f2a27 Backport from xs. 2 år sedan

README.md

snac

A simple, minimalistic ActivityPub instance

Features

  • Lightweight, minimal dependencies
  • Extensive support of ActivityPub operations, e.g. write public notes, follow users, be followed, reply to the notes of others, admire wonderful content (like or boost), write private messages...
  • Simple but effective web interface
  • Multiuser
  • Easily-accessed MUTE button to silence morons
  • Tested interoperability with related software
  • No database needed
  • Totally JavaScript-free
  • No cookies either
  • Not much bullshit

About

This program runs as a daemon (proxied by a TLS-enabled real httpd server) and provides the basic services for a Fediverse / ActivityPub instance (sharing messages and stuff from/to other systems like Mastodon, Pleroma, Friendica, etc.).

This is not the manual; man pages snac(1) (user manual), snac(5) (formats) and snac(8) (administrator manual) are what you are looking for.

snac stands for Social Networks Are Crap.

Installation

This 2.x release is written in C (unlike the 1.x prototype, which was written in Python). The only external dependencies are openssl and curl.

On Debian/Ubuntu, you can satisfy these requirements by running

    apt install libssl-dev libcurl4-openssl-dev

On OpenBSD you also need to install curl:

    pkg_add curl

Run make and then make install as root.

See the administrator manual on how to proceed from here.

Testing via Docker

A docker-compose file is provided for development and testing. To start snac with an nginx HTTPS frontend, run:

docker-compose build && docker-compose up

This will:

  • Start snac, storing data in data/
  • Configure snac to listen on port 8001 with a server name of localhost (see examples/docker-entrypoint.sh)
  • Create a new user testuser and print the user's generated password on the console (see examples/docker-entrypoint.sh)
  • Start nginx to handle HTTPS, using the certificate pair from nginx-alpine-ssl/nginx-selfsigned.* (see examples/nginx-alpine-ssl/entrypoint.sh)

License

See the LICENSE file for details.

Author

grunfink @grunfink@comam.es