Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rugk/mastodon-simplified-federation
Simplifies following and interacting with remote users on other Mastodon instances.
https://github.com/rugk/mastodon-simplified-federation
browser-addon browser-extension decentralization decentralized fediverse firefox-addon hacktoberfest mastodon web-extension webextension
Last synced: 6 days ago
JSON representation
Simplifies following and interacting with remote users on other Mastodon instances.
- Host: GitHub
- URL: https://github.com/rugk/mastodon-simplified-federation
- Owner: rugk
- License: other
- Created: 2018-08-15T21:33:09.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-01-07T02:38:03.000Z (about 1 year ago)
- Last Synced: 2024-04-13T21:11:53.942Z (9 months ago)
- Topics: browser-addon, browser-extension, decentralization, decentralized, fediverse, firefox-addon, hacktoberfest, mastodon, web-extension, webextension
- Language: JavaScript
- Homepage: https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation/?utm_source=github.com&utm_medium=github&utm_content=github-url-description&campaign=github-url-description
- Size: 3.46 MB
- Stars: 249
- Watchers: 10
- Forks: 17
- Open Issues: 34
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Mastodon – Simplified Federation!
[![Mozilla Add-on version](https://img.shields.io/amo/v/mastodon-simplified-federation.svg)](https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation/?utm_source=github.com&utm_medium=git&utm_content=badge-version&campaign=github)
[![Mozilla Add-on downloads](https://img.shields.io/amo/d/mastodon-simplified-federation.svg)](https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation/?utm_source=github.com&utm_medium=git&utm_content=badge-downloads&campaign=github)
[![Mozilla Add-on users](https://img.shields.io/amo/users/mastodon-simplified-federation.svg)](https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation/?utm_source=github.com&utm_medium=git&utm_content=badge-users&campaign=github)
[![Mozilla Add-on stars](https://img.shields.io/amo/stars/mastodon-simplified-federation.svg)](https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation/reviews/?utm_source=github.com&utm_medium=git&utm_content=badge-stars&campaign=github)Simplifies following or interacting with other users on remote Mastodon instances in the Fediverse. Basically, it skips the "Enter your Mastodon handle" popup and takes you directly to your own "home" instance, saving you from cumbrously entering your Mastodon handle again and again in that input box when you click on a “Follow”, “Retoot”/“Fav” or other remote interaction button on another instance. :smile:
[Idea by](https://social.wxcafe.net/@akkes/100550833588126733) [@akkes](https://social.wxcafe.net/@akkes).
## Download
**[![Get it for Firefox!](https://extensionworkshop.com/assets/img/documentation/publish/get-the-addon-178x60px.dad84b42.png)](https://addons.mozilla.org/firefox/addon/mastodon-simplified-federation?utm_source=github.com&utm_medium=git&utm_content=download-button&campaign=github)**
> **BTW:** If you want to generate QR codes privately, do check out our **[Offline QR Code Generator](https://github.com/rugk/offline-qr-code)** too!
## In action…
[![GIF demo showing how I click on a reply button and directly get to the toot site and how I click on follow and directly get to the page, where I can click "Follow"](assets/screencasts/mastodonSimplifiedFederationDemo.gif)](assets/screencasts/mastodonSimplifiedFederationDemo.gif)
## Why?
You may wonder why to use this browser add-on. But actually, it's easy!
You do not need to enter your Mastodon account handle anymore! (except for login :wink:) This makes interacting with remote instances much simpler.
Additionally, this add-on makes sure to keep your Mastodon handle **private**. It will never expose it to any third-party site. Therefore it does not – literally – enter your Mastodon ID into the input field you normally see, but basically "skips" this page. For the technical details, on how this works, see [How does it work?](#how-does-it-work) below.
## How does it work?
1. It intercepts any remote interaction popup/request.
2. It tries to get the toot/account you want to interact with from the "Enter your Mastodon ID" popup.
1. for remote follows: It get's the account to follow from the URL.
2. for toot interactions:
1. It gets the local toot ID from the URL.
2. It sends an additional web request to the remote server to get the remote toot ID.
Alternatively, it does try to get the remote toot URL from the "Enter your Mastodon ID" popup when it is shown/rendered.
3. Afterwards it redirects you to the "remote_follow"/"remote_interaction" endpoint of your own Mastodon instance directly, thus skipping entering the Mastodon handle in that "foreign" page.Due to the fact that it does not block loading of the "Enter your Mastodon ID" popup, it may – especially in the case of "toot interactions" – happen, that the "Enter your Mastodon ID" popup is shown anyway for some seconds. After some time, it should be redirected though.
If it really fails, this behavior ensures you still have a fallback to be able to manually enter your Mastodon handle.Note for new Mastodon v4 instances, this is not enough. It also needs to inject some code into the website and modify Mastodon instances. [See the release adding compatibility](https://github.com/rugk/mastodon-simplified-federation/releases/tag/v2.0) to see what is done in detail.
### Other Fediverse instances
Note this add-on also include (partially limited) support for redirecting other Fediverse instances to your Mastodon instance.
There, it may use different (or similar) methods for getting information about the user you want to follow.Note, however, it only triggers when a redirect/loading of an URL specific to a Fediverse type occurs. As such, it e.g. cannot “intercept” small text-fields, where you can enter your handle, inside of a page.
Here a short description on how it is done:
* for GNU Social: It can get the user from the URL, if the URL is `/main/ostatus/nickname/`.
* for Pleroma: If `/main/ostatus` is accessed, it tries to get the the username from the referrer. If not possible, it tries to scrape it from the website.
* for Friendica: It can get the user from the URL, if the URL is e.g. `/main/remote_follow/`.## Contribute
You can easily get involved in this FLOSS project and any help is certainly appreciated. Here are some ideas:
* 📃 [Translate this add-on into multiple languages!](./CONTRIBUTING.md#translations)
* 🐛 [Fix some easy issues and get started in add-on development](CONTRIBUTING.md#coding) (or just try out the development version)
* 💡 [Or check out some other add-on issues](CONTRIBUTING.md#need-ideas) (or translate them).Or, in any case, [support us by spreading the word!](./CONTRIBUTING.md#support-us) ❤️