back to home

C4illin / ConvertX

💾 Self-hosted online file converter. Supports 1000+ formats ⚙️

16,205 stars
889 forks
94 issues
TypeScriptJavaScriptDockerfile

AI Architecture Analysis

This repository is indexed by RepoMind. By analyzing C4illin/ConvertX in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.

Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context on-demand, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.

Source files are only loaded when you start an analysis to optimize performance.

Embed this Badge

Showcase RepoMind's analysis directly in your repository's README.

[![Analyzed by RepoMind](https://img.shields.io/badge/Analyzed%20by-RepoMind-4F46E5?style=for-the-badge)](https://repomind.in/repo/C4illin/ConvertX)
Preview:Analyzed by RepoMind

Repository Overview (README excerpt)

Crawler view

ConvertX A self-hosted online file converter. Supports over a thousand different formats. Written with TypeScript, Bun and Elysia. Features • Convert files to different formats • Process multiple files at once • Password protection • Multiple accounts Converters supported | Converter | Use case | Converts from | Converts to | | --------------------------------------------------------------- | ---------------- | ------------- | ----------- | | Inkscape | Vector images | 7 | 17 | | libjxl | JPEG XL | 11 | 11 | | resvg | SVG | 1 | 1 | | Vips | Images | 45 | 23 | | libheif | HEIF | 2 | 4 | | XeLaTeX | LaTeX | 1 | 1 | | Calibre | E-books | 26 | 19 | | LibreOffice | Documents | 41 | 22 | | Dasel | Data Files | 5 | 4 | | Pandoc | Documents | 43 | 65 | | msgconvert | Outlook | 1 | 1 | | VCF to CSV | Contacts | 1 | 1 | | dvisvgm | Vector images | 4 | 2 | | ImageMagick | Images | 245 | 183 | | GraphicsMagick | Images | 167 | 130 | | Assimp | 3D Assets | 77 | 23 | | FFmpeg | Video | ~472 | ~199 | | Potrace | Raster to vector | 4 | 11 | | VTracer | Raster to vector | 8 | 1 | | Markitdown | Documents | 6 | 1 | Any missing converter? Open an issue or pull request! Deployment > [!WARNING] > If you can't login, make sure you are accessing the service over localhost or https otherwise set HTTP_ALLOWED=true or Then visit in your browser and create your account. Don't leave it unconfigured and open, as anyone can register the first account. If you get unable to open database file run on the path you choose. Environment variables All are optional, JWT_SECRET is recommended to be set. | Name | Default | Description | | ---------------------------- | -------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------- | | JWT_SECRET | when unset it will use the value from randomUUID() | A long and secret string used to sign the JSON Web Token | | ACCOUNT_REGISTRATION | false | Allow users to register accounts | | HTTP_ALLOWED | false | Allow HTTP connections, only set this to true locally | | ALLOW_UNAUTHENTICATED | false | Allow unauthenticated users to use the service, only set this to true locally | | AUTO_DELETE_EVERY_N_HOURS | 24 | Checks every n hours for files older then n hours and deletes them, set to 0 to disable | | WEBROOT | | The address to the root path setting this to "/convert" will serve the website on "example.com/convert/" | | FFMPEG_ARGS | | Arguments to pass to the input file of ffmpeg, e.g. . See https://github.com/C4illin/ConvertX/issues/190 for more info about hw-acceleration. | | FFMPEG_OUTPUT_ARGS | | Arguments to pass to the output of ffmpeg, e.g. | | HIDE_HISTORY | false | Hide the history page | | LANGUAGE | en | Language to format date strings in, specified as a BCP 47 language tag | | UNAUTHENTICATED_USER_SHARING | false | Shares conversion history between all unauthenticated users | | MAX_CONVERT_PROCESS | 0 | Maximum number of concurrent conversion processes allowed. Set to 0 for unlimited. | Docker images There is a tag that is updated with every release and a tag that is updated with every push to the main branch. is recommended for normal use. The image is available on GitHub Container Registry and Docker Hub. | Image | What it is | | -------------------------------------- | -------------------------------- | | | The latest release on ghcr | | | The latest commit on ghcr | | | The latest release on docker hub | | | The latest commit on docker hub | Tutorial > [!NOTE] > These are written by other people, and may be outdated, incorrect or wrong. Tutorial in french: Tutorial in chinese: Tutorial in polish: Screenshots Development • Install Bun and Git • Clone the repository • • Pull requests are welcome! See open issues for the list of todos. The ones tagged with "converter request" are quite easy. Help with docs and cleaning up in issues are also very welcome! Use conventional commits for commit messages. Contributors Star History