No description
Find a file
2022-05-02 18:23:29 +01:00
.github/workflows Create rust.yml 2022-04-25 23:27:58 +01:00
git - added new pasta type URL and automatic redirection endpoint 2022-04-23 16:47:36 +01:00
src File upload and persistence extension 2022-05-02 16:53:10 +01:00
static - added water.css 2022-04-23 17:06:48 +01:00
templates File upload and persistence extension 2022-05-02 16:53:10 +01:00
Cargo.toml File upload and persistence extension 2022-05-02 16:53:10 +01:00
LICENSE Create LICENSE 2022-04-27 16:00:53 +01:00
README.MD Update README.MD 2022-05-02 18:23:29 +01:00

MicroBin

Screenshot

MicroBin is a super tiny and simple self hosted pastebin app written in Rust. The executable is around 6MB and it uses 2MB memory (plus your pastas, because they are all stored in the memory at the moment).

Features

  • Is very small
  • File uploads
  • Raw pasta content (/raw/[animals])
  • URL shortening and redirection
  • Automatic dark mode (follows system preferences)
  • Very simple database (json + files) for portability and easy backups
  • Animal names instead of random numbers for pasta identifiers (64 animals)
  • Automatically expiring pastas
  • Never expiring pastas
  • Listing and manually removing pastas (/pastalist)
  • Very little CSS and absolutely no JS (see water.css)

Installation

Simply clone the repository, build it with cargo build --release and run the microbin executable in the created target/release/ directory. It will start on port 8080. You can change the port with -p or --port CL arguments.

To install it as a service on your Linux machine, create a file called /etc/systemd/system/microbin.service, paste this into it with the value of ExecStart replaced with the actual path to microbin on your machine.

[Unit]
Description=MicroBin
After=network.target
[Service]
Type=simple
Restart=always
ExecStart=/home/pi/microbin/target/release/microbin
[Install]
WantedBy=multi-user.target

Then start the service with systemctl start microbin and enable it on boot with systemctl enable microbin.

Create Pasta with cURL

Simple text Pasta: curl -d "expiration=10min&content=This is a test pasta" -X POST https://microbin.myserver.com/create

File contents: curl -d "expiration=10min&content=$( < mypastafile.txt )" -X POST https://microbin.myserver.com/create

Available expiration options:

  • 1min
  • 10min
  • 1hour
  • 24hour
  • 1week
  • never

Use cURL to read the pasta: curl https://microbin.myserver.com/rawpasta/fish-pony-crow

or to download the pasta: curl https://microbin.myserver.com/rawpasta/fish-pony-crow > output.txt

Needed improvements

  • Persisting pastas on disk (currently they are lost on restart) (added on 2 May 2022)
  • Removing pasta after N reads
  • File uploads (added on 2 May 2022)
  • URL shortening (added on 23 April 2022)
  • CLI tool
  • Configuration with command line arguments (ports, enable-disable pasta list, footer, etc)