6d4eca0131
This now returns the list of instances of multiple Fediverse projects. Currently pretty slow because of the Mastodon and Pleroma being too big. |
||
---|---|---|
.github | ||
assets | ||
public | ||
script | ||
src | ||
.editorconfig | ||
.eslintignore | ||
.eslintrc.json | ||
.gitignore | ||
.pre-commit-config.yaml | ||
.prettierignore | ||
.vercelignore | ||
astro.config.ts | ||
CHANGELOG.md | ||
LICENSE | ||
package.json | ||
pnpm-lock.yaml | ||
README.md | ||
tsconfig.json | ||
vercel.json |
Instance-agnostic share page for the Fediverse.
Share₂Fedi allows you to share stuff on Mastodon, GoToSocial, Pleroma, and other federated social networks, instance-agnostic. Just type in the post text and the instance URL, and click ‘Post!’
Or, open this page with the prefilled text
URL parameter—it will be
automatically inserted into the text field. The same goes for the instance
URL
parameter. This can be used to build custom share buttons for the federated
social networks:
<a
href="https://s2f.kytta.dev/?text=Hello%20world!&instance=https%3A%2F%2Fmastodon.xyz"
>
Share on mastodon.xyz
</a>
The instance URL can be saved in your localStorage
to be automatically
appended if used later—handy!
Hosting
Vercel, Netlify, Cloudflare Pages
Share₂Fedi was designed to run on Vercel, but you can also run it on Netlify or Cloudflare Pages. To deploy it yourself (it's free!), you can use the following buttons:
To deploy to Cloudflare Pages, fork the repo and follow the instructions.
Host it yourself
Self-hosting Share₂Fedi outside of Vercel requires some extra setup:
Prerequisites: modern Node.js (v16 or later), pnpm
.
-
Install dependencies.
pnpm install
-
Build.
pnpm build
-
Run server.
By default, this will only listen on localhost port 3000. To enable listening on a ceratin hostand/or port, set the
HOST
andPORT
environment variables, respectively.node dist/server/entry.mjs
alternatively, if you want to run the process in the background:
pm2 start dist/server/entry.mjs --watch --ignore-watch="node_modules"
You can find a summary for pm2 at: https://pm2.keymetrics.io/docs/usage/quick-start/
More information about self-hosting an Astro website with Node: https://docs.astro.build/en/guides/integrations-guide/node/#standalone
-
Set up a reverse proxy.
Basically, you need to run a reverse proxy that would redirect all incoming requests to
localhost:3000
. Here's how to achieve this in various HTTP servers:- Apache
ProxyPass "/" "http://localhost:3000/"
- Nginx
location / { proxy_pass http://localhost:3000/; }
- Caddy
reverse_proxy :3000
See also
📯 Shareon (lightweight, stylish, and ethical share buttons) uses Share₂Fedi under the hood!
Licence
© 2020–2022 Nikita Karamov
Licensed under the GNU Affero General Public License, version 3.
This project is hosted on GitHub: https://github.com/kytta/share2fedi.git