Skip to content

langyo/0721

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

69 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

0721

clippy workflow GitHub License GitHub Tag

Ciallo~(∠·ω< )⌒★

A simple engine for image hosting written in Rust.

Features

  • Image hosting
  • Automatic image compression via WebP
  • Basic account system
  • Internationalization
  • Deploy via Docker
  • Written in pure Rust

Deploy

docker run -d -p 8080:80 -v image-cache:/home/cache ghcr.io/langyo/0721:latest

Configuration

You can configure the engine via Config.toml in the docker volume.

If you want to change the configuration, you might need to enter the container via the other image:

docker run -it --rm -v image-cache:/home busybox:latest

Then you can edit the Config.toml in the /home directory by using vi.

[portal]
# The site's title
title-suffix = "Ciallo~(∠·ω< )⌒★"
# The banner in the footer
footer-banner = [
    { text = "© 0721 project", url = "https://github.com/langyo/0721" },
]
# The default language of the site
language = "zh_hans"
# The timezone of the server, it will affect the images' timeline page
timezone = +8

[router]
# The entry path of the images
media-entry-path = "/media"
# If it's empty, it means no limit
limit-referrer-host = []

[upload]
# Allow to use "KiB", "MiB" as unit, or pure number string as bytes
image-size-limit = "8MiB"
# If it's true, the uploaded image will be converted to WebP format automatically
webp-auto-convert = true
# If it's true, the uploaded image will keep the original file's name
use-source-file-name = false

JWT secret key can be configured via the environment variable JWT_SECRET.

You can configure it via the additional command line argument -e JWT_SECRET=your_secret_key for the docker run command.