No Description

Emrik Östling fe22b2f8fb Merge pull request #344 from C4illin/fix/158/update-favicon 1 month ago
.github bd36314f00 chore: change to major version only 1 month ago
.vscode 1be11708c4 chore: format all files 1 month ago
images 88173891ba fix: wrong layout on search with few options 10 months ago
public 827f22e2fc fix: update favicon 1 month ago
src 3bf82b5b86 fix: move color variables to seperate directory 1 month ago
.dockerignore 9e759a75de refactor: split main file to pages 1 month ago
.gitignore d2cd6706c9 chore: update @elysiajs/static 9 months ago
CHANGELOG.md 01c8fad012 chore(main): release 0.14.1 1 month ago
Dockerfile cc41be6856 Merge branch 'main' of https://github.com/C4illin/ConvertX 1 month ago
LICENSE 16c1460620 Create LICENSE 1 year ago
README.md f789d9dfe3 fix: add language env 1 month ago
SECURITY.md 9277c27a50 chore: change security url 4 months ago
biome.json 1be11708c4 chore: format all files 1 month ago
bun.lock b32f7dba5d chore(deps): update dependency bun-types to v1.2.17 1 month ago
compose.yaml 1be11708c4 chore: format all files 1 month ago
eslint.config.ts 1be11708c4 chore: format all files 1 month ago
knip.json c1428f5c2b chore: fix knip 1 month ago
package.json b32f7dba5d chore(deps): update dependency bun-types to v1.2.17 1 month ago
postcss.config.js 1be11708c4 chore: format all files 1 month ago
prettier.config.js 1be11708c4 chore: format all files 1 month ago
renovate.json 1be11708c4 chore: format all files 1 month ago
reset.d.ts 1be11708c4 chore: format all files 1 month ago
tsconfig.json e8ed10dde8 chore(deps): update @elysiajs/html to version 1.1.1 9 months ago

README.md

ConvertX

ConvertX

Docker ghcr.io Pulls Docker Pulls GitHub Release GitHub commits since latest release GitHub repo size Docker container size

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
libheif HEIF 2 4
XeLaTeX LaTeX 1 1
Calibre E-books 26 19
Pandoc Documents 43 65
dvisvgm Vector images 4 2
ImageMagick Images 245 183
GraphicsMagick Images 167 130
Inkscape Vector images 7 17
Assimp 3D Assets 77 23
FFmpeg Video ~472 ~199
Potrace Raster to vector 4 11

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

# docker-compose.yml
services:
  convertx:
    image: ghcr.io/c4illin/convertx
    container_name: convertx
    restart: unless-stopped
    ports:
      - "3000:3000"
    environment:
      - JWT_SECRET=aLongAndSecretStringUsedToSignTheJSONWebToken1234 # will use randomUUID() if unset
    volumes:
      - ./data:/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.

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 ffmpeg, e.g. -preset veryfast
HIDE_HISTORY false Hide the history page
LANGUAGE en Language to format date strings in, specified as a BCP 47 language tag

Docker images

There is a :latest tag that is updated with every release and a :main tag that is updated with every push to the main branch. :latest is recommended for normal use.

The image is available on GitHub Container Registry and Docker Hub.

Image What it is
image: ghcr.io/c4illin/convertx The latest release on ghcr
image: ghcr.io/c4illin/convertx:main The latest commit on ghcr
image: c4illin/convertx The latest release on docker hub
image: c4illin/convertx:main The latest commit on docker hub

Release image size Dev image size

Tutorial

[!NOTE] These are written by other people, and may be outdated, incorrect or wrong.

Tutorial in french: https://belginux.com/installer-convertx-avec-docker/

Tutorial in chinese: https://xzllll.com/24092901/

Screenshots

ConvertX Preview

Development

  1. Install Bun and Git
  2. Clone the repository
  3. bun install
  4. bun run dev

Pull requests are welcome! See below and open issues for the list of todos.

Use conventional commits for commit messages.

Todo

  • Add options for converters
  • Add tests
  • Make errors logs visible from the web ui
  • Add more converters:

Contributors

Image with all contributors

Star History

Star History Chart