this post was submitted on 01 Jul 2023
20 points (100.0% liked)

wefwef

4212 readers
1 users here now

wefwef is now Voyager! Subscribe to !voyagerapp@lemmy.world.

founded 2 years ago
MODERATORS
 

I believe that self-hosting will take some of the load off of the wefwef server. That will be a win-win for everyone. At the same time, I understand that wefwef is still so very new that it might not be mature enough to let loose on other people's servers.

I am looking for instructions on how to self-host wefwef, ideally as a docker container, ideally using a ready-to-use docker-compose.yml file.

top 11 comments
sorted by: hot top controversial new old
[–] some_linux_user@lemmy.world 7 points 2 years ago

If you prefer to use docker compose you can write your own docker-compose.yml file like I did.

version: "3"

services:
  wefwef:
    container_name: wefwef
    image: ghcr.io/aeharding/wefwef:latest
    ports:
      - 5314:5314
    restart: unless-stopped # remove this is you don't want wefwef to run always

You should be able to access wefwef with http://localhost:5314 if you're running on your local machine, or if you have it running on something else access it with http://<ip address>:5314.

[–] FrayDabson@vlemmy.net 5 points 2 years ago (3 children)

pull image docker pull ghcr.io/aeharding/wefwef:latest start container: docker run --rm -it -p 5314:5314 wefwef

Source : https://github.com/aeharding/wefwef#prebuilt

[–] CriticalMiss@lemmy.world 1 points 2 years ago

Instead of doing 5314:5314 do 127.0.0.1:5314:5314. The setting provided in your post bypasses your firewall settings (assuming you're on Ubuntu Server, that's ufw) and set up a nginx reverse proxy with certbot.

[–] kobra@lemmy.world 1 points 2 years ago* (last edited 2 years ago)

To clarify a couple of things, and hopefully help anyone else doing this on macOS:

Start by installing Docker desktop

Open Terminal and type in:

docker pull ghcr.io/aeharding/wefwef:latest

Then, you want to use a Docker run command like this to get things started. In this example, I put my local IP in as "192.168.1.2" but you'll need to adjust that value to whatever your machine's IP is.

docker run --rm -d -p 192.168.1.2:5314:5314 -e "CUSTOM_LEMMY_SERVERS=lemmy.world,sh.itjust.works,lemmy.ml" ghcr.io/aeharding/wefwef:latest

At that point, I went to my iPhone, opened Safari and went to 192.168.1.2:5314 and boom, there's wefwef. Install this as PWA and name it (local) or something and you're good to go.

[–] shenandoah@sh.itjust.works 1 points 2 years ago

When I self host in my private network, wefwef should work from abroad as it‘s loaded on my phone - but does it pull new posts then?

[–] balder1991@lemmy.world 1 points 2 years ago* (last edited 2 years ago) (2 children)

Isn’t the whole JavaScript just in the device in PWAs? That’s why it needs an “update” action from the user to change to a new version.

[–] CriticalMiss@lemmy.world 2 points 2 years ago

You pull the code to your device but until CORS is properly implemented, the web server serves as a proxy to pull new content

[–] andynbaker@lemmy.world 1 points 2 years ago (1 children)

Yeah how do PWA’s actually work? Where is the code hosted? Is my login information stored on someone else’s server? I can easily spin up the wefwef container, but does that means anyone can then start leveraging my instance?

[–] CriticalMiss@lemmy.world 4 points 2 years ago (1 children)

PWAs are basically caching the assets on your phone. The code is kept on your phone but for any web requests you still phone home until CORS is properly implemented on Lemmy's side. Hard to say about your login information, because that depends on if the code was modified before the instance was put up. If you compile from source, then no, no information is collected. However, as of now wefwef is the one that's sending your password to the lemmy instance for authentication. You can easily spin up a wefwef container, whether you grant permissions for others to use it is based on your firewall rules as by default wefwef is open for anyone to use. But, you can restrict ports 80 and 443 to only work with your IP if it's static or set up a VPN. My instance is open but I don't advertise it anywhere as I'm not sure it's ready to carry the load, so just my friends use it.

[–] balder1991@lemmy.world 1 points 2 years ago

Thanks for the explanation.

[–] pacology@lemmy.world 1 points 2 years ago

Check the GitHub repo. They have a docket file you can build and self host alongside some instructions on how to change the radiotherapy servers.

If you want a prebuilt image, search on docket hub. There is at least one I have seen.

Note that the default image doesn’t come with a reverse proxy, so you will want to put it behind something like nginx or caddy to take care of the SSL stuff.

load more comments
view more: next ›