Your self-hosted, globally interconnected microblogging community
 
 
 
 
 
 
Go to file
Eugen Rochko 75b3339a99 Respect "delete" verb on remote feeds 2016-03-16 10:46:15 +01:00
app Respect "delete" verb on remote feeds 2016-03-16 10:46:15 +01:00
bin
config Adding a docker-compose template for running Mastodon easily 2016-03-14 21:39:39 +01:00
db
lib
log
public
spec
vendor/assets
.dockerignore Respect "delete" verb on remote feeds 2016-03-16 10:46:15 +01:00
.env.production.sample Adding a docker-compose template for running Mastodon easily 2016-03-14 21:39:39 +01:00
.gitignore Ignore future .env files - those should not be committed to VC! Nor be part of docker containers 2016-03-14 21:44:30 +01:00
.rspec
.ruby-version
Dockerfile Adding a docker-compose template for running Mastodon easily 2016-03-14 21:39:39 +01:00
Gemfile
Gemfile.lock
LICENSE
README.md Adding a docker-compose template for running Mastodon easily 2016-03-14 21:39:39 +01:00
Rakefile
config.ru
docker-compose.yml Adding a docker-compose template for running Mastodon easily 2016-03-14 21:39:39 +01:00

README.md

Mastodon

Mastodon is a federated microblogging engine. An alternative implementation of the GNU Social project. Based on ActivityStreams, Webfinger, PubsubHubbub and Salmon.

Current status of the project is early development. Documentation &co will be added later

Status

  • GNU Social users can follow Mastodon users
  • Mastodon users can follow GNU Social users
  • Retweets, favourites, mentions, replies work in both directions
  • Public pages for profiles and single statuses
  • Sign up, login, forgotten passwords and changing password
  • Mentions and URLs converted to links in statuses
  • REST API, including home and mention timelines
  • OAuth2 provider system for the API
  • Upload header image for profile page

Missing:

  • Media attachments (photos, videos)
  • UI to post, reblog, favourite, follow and unfollow
  • Deleting statuses, deletion propagation
  • Streaming API

Configuration

  • LOCAL_DOMAIN should be the domain/hostname of your instance. This is absolutely required as it is used for generating unique IDs for everything federation-related
  • LOCAL_HTTPS set it to true if HTTPS works on your website. This is used to generate canonical URLs, which is also important when generating and parsing federation-related IDs
  • HUB_URL should be the URL of the PubsubHubbub service that your instance is going to use. By default it is the open service of Superfeedr

Requirements

  • PostgreSQL
  • Redis

Running with Docker and Docker-Compose

The project now includes a Dockerfile and a docker-compose.yml. You need to turn .env.production sample into .env.production with all the variables set before you can:

docker-compose build

And finally

docker-compose up

As usual, the first thing you would need to do would be to run migrations:

docker-compose run web rake db:migrate