mirror of
				https://github.com/C4illin/ConvertX.git
				synced 2025-11-04 05:53:45 +00:00 
			
		
		
		
	
			
				
					
						
					
					0a10a56ae3314c3765660e3ec4b51083bfdf9c19
				
			
			
		
	chore(deps): update oven/bun docker tag to v1.1.32
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 | 
|---|---|---|---|
| libjxl | JPEG XL | 11 | 11 | 
| resvg | SVG | 1 | 1 | 
| Vips | Images | 45 | 23 | 
| Assimp | 3D Assets | 70 | 24 | 
| XeLaTeX | LaTeX | 1 | 1 | 
| Pandoc | Documents | 43 | 65 | 
| GraphicsMagick | Images | 166 | 133 | 
| FFmpeg | Video | ~473 | ~280 | 
Any missing converter? Open an issue or pull request!
Deployment
# docker-compose.yml
services:
  convertx: 
    image: ghcr.io/c4illin/convertx
    container_name: convertx
    restart: unless-stopped
    ports:
      - "3000:3000"
    environment: # Defaults are listed below. All are optional.
      - ACCOUNT_REGISTRATION=false # true or false, doesn't matter for the first account (e.g. keep this to false if you only want one account)
      - JWT_SECRET=aLongAndSecretStringUsedToSignTheJSONWebToken1234 # will use randomUUID() by default
      - HTTP_ALLOWED=false # setting this to true is unsafe, only set this to true locally
      - ALLOW_UNAUTHENTICATED=false # allows anyone to use the service without logging in, 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
    volumes:
      - convertx:/app/data
or
docker run -p 3000:3000 -v ./data:/app/data ghcr.io/c4illin/convertx
Then visit http://localhost:3000 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 chown -R $USER:$USER path on the path you choose.
Tutorial
Tutorial in french: https://belginux.com/installer-convertx-avec-docker/
Screenshots
Development
- Install Bun and Git
 - Clone the repository
 bun installbun run dev
Pull requests are welcome! See below and open issues for the list of todos.
Todo
- Add messages for errors in converters
 - Add searchable list of formats
 - Add options for converters
 - Divide index.tsx into smaller components
 - Add tests
 - Make the upload button nicer and more easy to drop files on. Support copy paste as well if possible.
 - Make errors logs visible from the web ui
 - Add more converters:
 
Contributors
Star History
Description
				💾 Self-hosted online file converter. Supports 1000+ formats ⚙️
						
						
						
							
							bunconversionconvertconverterdocument-conversionelysiafile-conversionfile-converterhacktoberfestpdf-converterself-hostedtailwindcsstypescript
						
						
						
							
								 Readme
							
						
						
							
								 AGPL-3.0
							
						
						
						
							
							
							 5.4 MiB
						
					
					Languages
				
				
								
								
									TypeScript
								
								90.2%
							
						
							
								
								
									JavaScript
								
								5.4%
							
						
							
								
								
									Dockerfile
								
								2.8%
							
						
							
								
								
									CSS
								
								1.6%
							
						
					
