Skip to main content

A professional web-based file manager with dark theme UI

Project description

FileFy

Python Version License FileFy - Modern Cloud File Manager

A professional web-based File Manager Written in Python. Features a Beautiful Dark Theme UI, File Upload/Download, Remote URL Downloads With Progress Tracking, and Comprehensive File Operations.

Modern Cloud File Manager - FileFy
Modern Cloud File Manager - FileFy

Features

  • Professional Dark Theme UI - Modern, responsive design
  • File Upload - Drag & drop or click to upload files. Uploads are chunked, with per-file progress, pause / resume / cancel controls, and they survive transient connection drops.
  • File Download - Download files directly from the browser, with HTTP Range support so the in-browser transfer manager can pause and resume large local downloads.
  • Remote Download - Download files from URLs with progress tracking and pause / resume / cancel support. Screenshot
  • Compress - Right-click any file or folder and create an archive (.zip, .tar, .tar.gz) directly on the server.
  • Transfer Center - Centered, project-themed panel that shows every in-flight transfer (upload, download, remote download). It can be minimised to the sidebar and never gets stuck on a Cancelled / Error state — every row has Pause, Resume, Cancel and Dismiss controls.
  • Cloudflare Tunnel - Optional --tunnel flag that publishes the server through a free *.trycloudflare.com URL alongside the local one. Requires the cloudflared binary to be installed on PATH.
  • File Operations - Copy, move, rename, delete files and folders
  • Search - Quick file search functionality
  • Context Menu - Right-click menu with common actions
  • Keyboard Shortcuts - Ctrl+C, Ctrl+V, F2, Del, F5
  • File Preview - Preview text files and images
  • Disk Usage - View disk space information

Quick Start

Install from PyPI (One Command!)

pip install filefy

Run the File Manager

# Start with default settings (port 5000, home directory)
filefy

# Custom port
filefy --port 8080

# Custom directory
filefy --dir /path/to/directory

# Bind to specific host
filefy --host 127.0.0.1 --port 3000

# Enable debug mode
filefy --debug

# Also expose the server on a public Cloudflare tunnel
# (install cloudflared first: https://github.com/cloudflare/cloudflared)
filefy --tunnel

Then open your browser and go to: http://localhost:5000

Installation Methods

Method 1: pip (Recommended)

pip install filefy

Method 2: From Source

git clone https://github.com/Pymmdrza/filefy.git
cd filefy
pip install -e .

Method 3: Using pipx (Isolated Environment)

pipx install filefy

Method 4: Docker (GitHub Container Registry)

Pre-built multi-arch (linux/amd64, linux/arm64) images are published on every push to the default branch and on every v* tag at ghcr.io/pymmdrza/filefy.

# Pull and run the latest image, mounting the host directory you want to manage
docker run -d \
  --name filefy \
  -p 5000:5000 \
  -v "$PWD/data:/data" \
  ghcr.io/pymmdrza/filefy:latest

Open http://localhost:5000 to use the file manager. The container exposes the following environment variables (all optional):

Variable Default Description
FILEFY_HOST 0.0.0.0 Interface to bind the server to
FILEFY_PORT 5000 Port to listen on (inside the container)
FILEFY_DIR /data Base directory exposed by the manager

Pin a specific version by tag, e.g. ghcr.io/pymmdrza/filefy:v1.0.0.

Docker Compose

A ready-to-use docker-compose.yml is included:

docker compose up -d

This will mount ./data into the container and expose the UI on http://localhost:5000. Replace the image: line with build: . to build the image locally from the source tree instead of pulling from GHCR.

Build the image yourself

git clone https://github.com/Pymmdrza/filefy.git
cd filefy
docker build -t filefy:local .
docker run --rm -p 5000:5000 -v "$PWD/data:/data" filefy:local

CLI Usage

usage: filefy [-h] [-H HOST] [-p PORT] [-d DIR] [--debug] [--tunnel] [-v]

filefy - Professional Web-Based File Manager

options:
  -h, --help            show this help message and exit
  -H, --host HOST       Host to bind the server to (default: 0.0.0.0)
  -p, --port PORT       Port to run the server on (default: 5000)
  -d, --dir DIR         Base directory for file management (default: home)
  --debug               Enable Flask debug mode
  --tunnel              Also publish the server through a Cloudflare quick
                        tunnel and print the public URL alongside the local
                        URL. Requires the 'cloudflared' binary on PATH.
  -v, --version         show program's version number and exit

Examples:
  filefy                         Start with default settings
  filefy -p 8080                 Use port 8080
  filefy --host 127.0.0.1        Only allow local connections
  filefy -d /home/user/files     Set base directory
  filefy --debug                 Enable Flask debug mode
  filefy --tunnel                Also expose a public Cloudflare URL

Python API

You can also use filefy programmatically:

from filefy import app, create_app
from filefy.server import run

# Option 1: Run with default settings
run()

# Option 2: Run with custom settings
run(host='127.0.0.1', port=8080, base_dir='/home/user/files')

# Option 3: Get Flask app for custom deployment
app = create_app(base_dir='/var/www/files')
# Use with gunicorn, waitress, etc.

Using with Gunicorn

pip install gunicorn
gunicorn "filefy:create_app()" -b 0.0.0.0:8000 -w 4

Using with Waitress (Windows)

pip install waitress
waitress-serve --listen=0.0.0.0:8000 filefy:app

Development

Setup Development Environment

git clone https://github.com/Pymmdrza/filefy.git
cd filefy
python -m venv .venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate
pip install -e ".[dev]"

[!NOTE] More details about API

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Made by MMdrza

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

filefy-2.0.0.tar.gz (84.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

filefy-2.0.0-py3-none-any.whl (80.5 kB view details)

Uploaded Python 3

File details

Details for the file filefy-2.0.0.tar.gz.

File metadata

  • Download URL: filefy-2.0.0.tar.gz
  • Upload date:
  • Size: 84.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for filefy-2.0.0.tar.gz
Algorithm Hash digest
SHA256 a565893b16e7bc04d8bc1174fbfd06f970b707782a8d95293db1adcf921938ec
MD5 395c03cc27d389bae875cc5ad4565f8b
BLAKE2b-256 e8567e35c25d6deb352bdd28f9a31beb35321f771cd5401b5d334a013a927dae

See more details on using hashes here.

File details

Details for the file filefy-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: filefy-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 80.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for filefy-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c4684380621e19feafa1842b7245f90c8a9ea173688b688097f165d3bba31363
MD5 a38213526f710b9e624861fa7d374ed9
BLAKE2b-256 70b2e160c8ee345ca9ea0883b0645166c3e04dc9b8d672885f2eeed30097c181

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page