script per siti che facilita la condivisione delle pagine web nelle istanze Mastodon toot ti permette di condividere URL su Mastodon, sunziona per qualsiasi istanza. Basta inserire il testo del tuo post e l'URL dell'istanza e cliccare su "Toot!". https://mastodon.it
Go to file
Nikita Karamov 3c3d779d3d
Disable function splitting
2023-09-02 21:56:54 +02:00
.github
assets
public
script
src
.editorconfig
.eslintignore
.eslintrc.json
.gitignore
.pre-commit-config.yaml
.prettierignore
.vercelignore
CHANGELOG.md
LICENSE
README.md
astro.config.mjs Disable function splitting 2023-09-02 21:56:54 +02:00
package.json
pnpm-lock.yaml
svelte.config.js
tsconfig.json
vercel.json

README.md

Share2Fedi

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:

Deploy to Vercel Deploy to Netlify

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.

  1. Install dependencies.

    pnpm install
    
  2. Build.

    pnpm build
    
  3. Run server.

    By default, this will only listen on localhost port 3000. To enable listening on a ceratin host and/or port, set the HOST and PORT environment variables, respectively.

    node dist/server/entry.mjs
    

    In production, you might want to use a process manager, like PM2:

    # Start the app, restart on file changes (except node_modules)
    pm2 start dist/server/entry.mjs --name "Share2Fedi" --watch --ignore-watch="node_modules"
    

    More information about self-hosting an Astro website with Node: https://docs.astro.build/en/guides/integrations-guide/node/#standalone

  4. 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:

    1. Apache
    ProxyPass "/" "http://localhost:3000/"
    
    1. Nginx
    location / {
        proxy_pass http://localhost:3000/;
    }
    
    1. Caddy
    reverse_proxy :3000
    

Docker

If you really have to use Docker, there is a good guide on building Astro apps with Docker. I will not provide support for Docker-based deployments in the observable future.

See also

📯 Shareon (lightweight, stylish, and ethical share buttons) uses Share₂Fedi under the hood!

Licence

© 20202023 Nikita Karamov
Licensed under the GNU Affero General Public License v3.0 or later.


This project is hosted on GitHub: https://github.com/kytta/share2fedi.git