5.3 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	navigation, title, main
| navigation | title | main | ||
|---|---|---|---|---|
| true | File Browser | 
  | 
:ellipsis{left=0px width=40rem top=10rem blur=140px}
File Browser
::alert{type="info"} 🎯 Objectives:
- Install File Browser
 - Expose File Browser using Swag ::
 
File Browser is a web-based interface that lets you access and edit the files on your server.
Installation
Open Dockge, click on compose, name the stack filebrowser, then copy and paste the following:
---
services:
  filebrowser:
    container_name: filebrowser
    volumes:
      - /docker/filebrowser/config:/config/
      - /path/to/your/folders:/yourfolders #add your folders to browse as /docker:/docker for exemple
    ports:
      - 8010:80
    image: filebrowser/filebrowser:s6
::alert{type="success"} ✨ Tip: Add the watchtower label to each container to automate updates.
```yaml
services:
  filebrowser:
    #...
    labels:
      - com.centurylinklabs.watchtower.enable=true
::
Deploy the container and go to http://yourserverip:8010. That’s it—your File Browser web UI is up and running!
::alert{type="danger"} :::list{type="danger"}
- If it doesn’t work: check your firewall rules. ::: ::
 
Exposing File Browser with Swag
::alert{type="warning"} :::list{type="warning"}
- File Browser does not support multi-factor authentication. Exposing it publicly could put your systems at risk. Only do this if you’re using a secure authentication solution like Authentik. Otherwise, do not expose it with SWAG—use a VPN like Wireguard instead. ::: ::
 
You may want to access File Browser remotely from all your devices. To do that, we’ll expose it through Swag.
::alert{type="info"} :::list{type="info"}
- Pre-requisite: We assume you've already created a subdomain like 
files.yourdomain.comin your DNS zone pointing toyourdomain.comwith aCNAME, and—unless you're using Cloudflare Zero Trust—have already forwarded port443on your router to port443on your server using NAT rules. ::: :: 
In Dockge, go to the SWAG stack and edit the compose file to add File Browser’s network:
services:
  swag:
     container_name: # ...
      # ... 
     networks:                 # Connects the container to the custom network 
      # ...           
      - filebrowser            # Name of the network declared in the stack
    
networks:                      # Defines the custom network
  # ...
  filebrowser:                 # Name of the network declared in the stack
    name: filebrowser_default  # Actual name of the external network
    external: true             # Specifies it's an external network
::alert{type="info"} :::list{type="info"}
- Here, we assume the network name for File Browser is 
filebrowser_default. You can confirm the connection is working by accessing the SWAG dashboard at http://yourserverip:81. ::: :: 
Restart the stack by clicking "deploy" and wait for SWAG to fully initialize.
In the Swag folders, create the file files.subdomain.conf.
sudo vi /docker/swag/config/nginx/proxy-confs/files.subdomain.conf
Enter insert mode by pressing i, and paste the following configuration:
## Version 2023/12/19
server {
    listen 443 ssl;
    listen [::]:443 ssl;
    server_name files.*;
    include /config/nginx/ssl.conf;
    client_max_body_size 0;
    #if ($lan-ip = yes) { set $geo-whitelist yes; }
    #if ($geo-whitelist = no) { return 404; }
    if ($geo-blacklist = no) { return 404; }
    # enable for ldap auth (requires ldap-location.conf in the location block)
    #include /config/nginx/ldap-server.conf;
    # enable for Authelia (requires authelia-location.conf in the location block)
    #include /config/nginx/authelia-server.conf;
    # enable for Authentik (requires authentik-location.conf in the location block)
    #include /config/nginx/authentik-server.conf;
    location / {
        # enable the next two lines for http auth
        #auth_basic "Restricted";
        #auth_basic_user_file /config/nginx/.htpasswd;
        # enable for ldap auth (requires ldap-server.conf in the server block)
        #include /config/nginx/ldap-location.conf;
        # enable for Authelia (requires authelia-server.conf in the server block)
        #include /config/nginx/authelia-location.conf;
        # enable for Authentik (requires authentik-server.conf in the server block)
        #include /config/nginx/authentik-location.conf;
        include /config/nginx/proxy.conf;
        include /config/nginx/resolver.conf;
        set $upstream_app filebrowser;
        set $upstream_port 80;
        set $upstream_proto http;
        proxy_pass $upstream_proto://$upstream_app:$upstream_port;
    }
}
Press Esc, then save and exit with :x followed by Enter.
That’s it—File Browser is now exposed!
::alert{type="success"}
✨ Tip: You can protect this app with Authentik by opening files.subdomain.conf and uncommenting include /config/nginx/authentik-server.conf;{lang=nginx} and include /config/nginx/authentik-location.conf;{lang=nginx}. Don’t forget to create an application and provider in Authentik.
::
