Skip to content
A supported fork of Mastodon that provides local posting and a wider range of content types.
Branch: hometown-2.9.2
Clone or download
Pull request Compare This branch is 138 commits ahead, 136 commits behind tootsuite:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci Fix check-i18n builds (tootsuite#11084) Jun 16, 2019
.dependabot Change dependabot update schedule from live to weekly (tootsuite#10949) Jun 4, 2019
.github Add sponsor button to GitHub web UI (tootsuite#10814) May 23, 2019
app Add link to Hometown source in footer Jul 11, 2019
config Merge tag 'v2.9.2' into instance_only_statuses Jun 25, 2019
db Appropriate DB migrations now in place Jul 12, 2019
dist Cache error 410 responses in recommended nginx configuration (tootsui… Mar 30, 2019
log Initial commit Feb 20, 2016
nanobox Resync Nanobox files with the 2.9.0 release (tootsuite#11083) Jun 14, 2019
public Disallow robots from indexing /interact/ (tootsuite#10666) May 1, 2019
spec Merge tag 'v2.9.2' into instance_only_statuses Jun 25, 2019
streaming Merge tag 'v2.9.2' into instance_only_statuses Jun 25, 2019
vendor Increase files checked by ESLint (tootsuite#9705) Jan 4, 2019
.buildpacks Add ffmpeg buildpack for scalingo (tootsuite#8500) Aug 28, 2018
.codeclimate.yml Replace from scss-lint to sass-lint (tootsuite#10958) Jun 4, 2019
.dockerignore Add .bundle to .dockerignore (tootsuite#7895) Jun 26, 2018
.editorconfig Add final newline to locale files (tootsuite#2890) May 7, 2017
.env.nanobox Rename S3_CLOUDFRONT_HOST to S3_ALIAS_HOST. (tootsuite#8423) Aug 25, 2018
.env.production.sample Add ES_PREFIX in .env.production.sample (tootsuite#10087) May 9, 2019
.env.vagrant update vagrant configs (tootsuite#8706) Sep 16, 2018
.eslintignore Increase files checked by ESLint (tootsuite#9705) Jan 4, 2019
.eslintrc.js Refactor icons in web UI to use Icon component (tootsuite#9951) Jan 31, 2019
.foreman Replace sprockets/browserify with Webpack (tootsuite#2617) May 3, 2017
.gitignore Ignore elasticsearch directory (tootsuite#7070) Apr 8, 2018
.haml-lint.yml Added haml-lint and fix warnings (tootsuite#2773) May 8, 2017
.nanoignore Remove Storybook (tootsuite#4397) Jul 27, 2017
.nvmrc Upgrade Node.js to v8.x on nvmrc (tootsuite#8023) Jul 15, 2018
.profile Add ffmpeg and dependent packages as well as LD_LIBRARY_PATHs (tootsu… May 24, 2017
.rspec Adding a Mention model, test stubs Feb 24, 2016
.rubocop.yml require rubocop-rails in .rubocop.yml (tootsuite#10974) Jun 6, 2019
.yarnclean Replace from scss-lint to sass-lint (tootsuite#10958) Jun 4, 2019
Aptfile Adjust Aptfile for Heroku-18 stack (tootsuite#8588) Sep 9, 2018 Fix unconverted PRs in the changelog (tootsuite#11155) Jun 22, 2019 Update translating platform has changed to crowdin ( (t… Jun 16, 2019
Gemfile Bump capybara from 3.22.0 to 3.24.0 (tootsuite#11100) Jun 17, 2019
Gemfile.lock Bump capybara from 3.22.0 to 3.24.0 (tootsuite#11100) Jun 17, 2019
LICENSE Fix tootsuite#49 - License changed from GPL-2.0 to AGPL-3.0 Sep 21, 2016
Procfile More robust PuSH subscription refreshes (tootsuite#2799) May 5, 2017 Fix Procfile on OS X (tootsuite#6748) Mar 12, 2018 Update readme Jul 11, 2019
Rakefile Initial commit Feb 20, 2016
Vagrantfile Add clearer error when/if gpg fails to install (tootsuite#10228) Mar 10, 2019
babel.config.js New Crowdin translations (tootsuite#11077) Jun 18, 2019
boxfile.yml Fix rubocop issues, introduce usage of frozen literal to improve perf… Nov 15, 2016
crowdin.yml Update crowdin.yml Jun 12, 2019
docker-compose.yml Upgrade redis in docker-compose.yml from 4 to 5 (tootsuite#9063) May 19, 2019
package.json Bump enzyme-adapter-react-16 from 1.7.1 to 1.14.0 (tootsuite#11105) Jun 17, 2019
postcss.config.js Increase files checked by ESLint (tootsuite#9705) Jan 4, 2019
priv-config TOR federation (tootsuite#7875) Jun 26, 2018
scalingo.json Add ffmpeg buildpack for scalingo (tootsuite#8500) Aug 28, 2018
yarn.lock Bump enzyme-adapter-react-16 from 1.7.1 to 1.14.0 (tootsuite#11105) Jun 17, 2019

Hometown: a Mastodon fork

photo of a village of stone huts nestled in a lush green valley

Photo by Joana Mujollari, CC0 / Public Domain.

Mastodon is a free, open-source social network server based on ActivityPub. This is not the official version of Mastodon; this is a separate version (i.e. a fork) maintained by Darius Kazemi. For more information on Mastodon, you can see the official website and the upstream repo.

Hometown is a light weight fork of Mastodon. This fork is based on the principle of: minimum code change for maximum user experience change.

Hometown is launching with a few key differences from Mastodon.

  • Local only posting (aka posts that never federate)
  • Accepting more content types "natively", like in-line reading of full articles (behind a cut for length)
  • Some accessibility features set to default

Those are the only changes! They are pretty minor in terms of the source code involved, but they drastically change the experience of being on Mastodon. I'll explain each of these in more detail now.

Some changes are to come in the future:

  • Better list management

Migrating from Mastodon to Hometown

Please see this article in the wiki for directions on migration from Mastodon to Hometown.

Local only posting

Mastodon right now is designed to get your messages out to the entire fediverse. This is great, but there is a huge need for more private communities. And in a federated network I think it makes the most sense for your home server to be that community (hence "Hometown").

In the context of Hometown, local only posting is a per-post security option that lets you set whether that post can federate out to other servers or not.

I've been running Friend Camp, a Mastodon fork with local only posting, for about a year. Being able to have conversations with people on your server that don't federate is a hugely liberating thing. It allows inside jokes to develop. It allows people the freedom to complain about things that they wouldn't necessarily feel comfortable leaving a trusted server (cops, employers, etc). It also lets us do things like have a server-wide movie night where we flood the local timeline with posts about the movie, and it doesn't pollute the rest of the Fediverse.

This feature is based on the work of Renato Lond, which is itself based on a feature in the Mastodon Glitch Edition fork.

Reading more content types

Mastodon is microblogging software, meant for Twitter-style shortform posting.

Hometown is microblogging for writing, but its goal is to accept many content types for reading. So while I don't plan to let Hometown users publish massive blog posts, I would like your Hometown instance to be your one-stop shop for viewing all sorts of things on the Fediverse.

For Hometown this means if you subscribe to a service that sends out Article objects over ActivityPub (such as a blog on Write As), then those full articles render in your home timeline, behind a cut for length. Also, Hometown will render a variety of rich text like italic and bold.

Click on this GIF for a brief video demo:

Video demo of someone clicking 'read article' on an incoming article post, which then renders a full article.

This is based on rich text work by Thibaut Girka, and my own work on Article support.

It's more than just reading more stuff

Reading more content types also helps make the fediverse better. ActivityPub supports all kinds of content, but most ActivityPub servers shoehorn all their content into Note because that's the type that Mastodon treats as first-class. This has important implications for the fediverse and also on your day to do user experience.

Take the "quote tweet" debate for example.

Twitter has a feature called "quote tweeting" that lets you embed what someone else tweets, with your own comment right next to it. It's really useful for provide commentary in context, like this, where I point people to a sale and they can read both my comment on the sale and the original tweet about the sale in one post:

An example of a quote tweet from Twitter.

But it's also open to abuse with people quote-tweeting things they disagree with to encourage a pile-on from their followers. There's been a lot of debate among Mastodon users as to whether the good of this feature outweighs the bad. So far, Mastodon has avoided implementing quoting.

What does this have to do with content types? Well, if we support an Article content type and a Note content type, we can support quoting for an Article but not for a Note. In practice this means that you can quote blog posts and news articles, but you can't quote a quick personal microblog note.

Hometown doesn't support quoting articles yet... but it will.

Better list management

If Hometown is going to be a universal reader, you're going to need better control over organizing your feeds than mainline Mastodon provides.

Exclusive lists

My first plan is to introduce a new kind of exclusive list. Right now if you add an account to your "friends I like" list in Mastodon, posts from people on that list appear on that list. But they also appear on your home timeline, and maybe you don't want that! You'd rather treat your "friends I like" list as your "real" home timeline, and then check your home timeline when you're bored.

Or another case: I might have all the blogs I read in one list, but I only check it on Saturdays when I have time to read things. In that case I don't want updates from those blogs clogging up my home timeline.

This is not yet implemented but will be available in the first release.

Better accessibility defaults

Look, right now this pretty much just means that we underline hyperlinks by default. I'm of course open to implementing other obviously beneficial accessibilty defaults that Mastodon itself doesn't implement.

Hometown is still 99.999% Mastodon

I don't intend to stray very far from mainline Mastodon with this fork. If you want something that provides a ton of new features and widgets and stuff, the Mastodon Glitch Edition fork is a wondrous kitchen sink of major and minor tweaks.

Part of why I don't want to stray far from mainline Mastodon is that this project is going to be just me for the foreseeable future, and I'd like to keep it up to date with new Mastodon versions as easily as possible. The less code I change from Mastodon, the easier that is. Hence the principle of "minimum code change for maximum user experience change."


Hometown follows Mastodon versioning, so Hometown v2.9.2 is up to date with Mastodon v2.9.2.


Copyright (C) 2016-2019 Eugen Rochko and other Mastodon contributors; see

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program. If not, see

You can’t perform that action at this time.