http paste webserver in go
Go to file
jabuxas e753301e33 chore: remove duplicated features
some mistake on my end while rebasing
2024-10-17 18:48:08 -03:00
.github/workflows ci: create docker image on tag creation 2024-09-19 13:17:29 -03:00
static feat: move upload page to home page 2024-10-15 15:35:45 -03:00
templates fix: make files cover all space available 2024-10-17 18:22:16 -03:00
.gitignore chore: update gitignore 2024-09-18 10:24:21 -03:00
abyss.go refactor: set values on Application creation 2024-10-17 15:26:13 -03:00
docker-compose.yml fix: limited /tmp space inside container 2024-09-19 15:39:11 -03:00
Dockerfile feat: optimize docker image 2024-09-06 10:33:57 -03:00
file_display.go feat: add support for fish scripts 2024-10-17 13:08:29 -03:00
generate_config.sh feat: add check on whether to restrict text uploading 2024-10-15 15:21:05 -03:00
go.mod feat: add tokens for authentication 2024-10-17 10:52:33 -03:00
go.sum feat: add tokens for authentication 2024-10-17 10:52:33 -03:00
handlers.go refactor: set values on Application creation 2024-10-17 15:26:13 -03:00
helpers.go feat: add tokens for authentication 2024-10-17 10:52:33 -03:00
LICENSE Initial commit 2024-08-19 11:55:06 -03:00
README.md chore: remove duplicated features 2024-10-17 18:48:08 -03:00

abyss

abyss is a basic and mostly single user http server written in go made for uploading files (logs, images) and then sharing them to the internet

homepage
this is abyss' default home page

table of contents

features

  • file uploads: supports uploading various file types, including images, videos, and documents.
  • flexible media display: automatically renders uploaded files on a webpage based on their type (images, pdfs, videos, or plain text).
  • easily customizable interface: allows for easy modification of color schemes and layout to suit specific design needs.
  • syntax highlighting for code: syntax highlighting available by default for code files, with support for multiple programming languages. (can be tweaked/changed and even removed)
  • security considerations: as it is single user, it's mostly secure but there are still some edges to sharpen

running:

  • run ./generate_config.sh to setup the necessary environment variables

docker

  • to run with docker, you can use the docker-compose.yml file available in this repo. to do so, run:
docker compose up -d # might be docker-compose depending on distro
  • you can optionally use the docker image directly and set it up how you want

manual

  • to run it manually, build it with go build -o abyss and run:
./abyss

uploading

with curl

  • you can upload both with the main key and with jwt tokens
main key
  • to upload your files with main key:
curl -F "file=@/path/to/file" -H "X-Auth: "$(cat /path/to/.key) http://localhost:3235/
  • you should probably create an alias or a function to do this automatically for you.
click for an example for bash/zsh:
pst() {
  local file

  if [[ -p /dev/stdin ]]; then
    file=$(mktemp)
    cat > "$file"
  elif [[ -n $1 ]]; then
    file="$1"
  else
    echo "Usage: pst [file]"
    return 1
  fi

  curl -F "file=@$file" -H "X-Auth: $(cat ~/.key)" http://localhost:3235/

  if [[ -p /dev/stdin ]]; then
    rm "$file"
  fi
}
click for an example for fish shell:
function pst
    set -l file

    if command test -p /dev/stdin
        set file "/tmp/tmp.txt"
        cat > $file
    else if test -n "$argv[1]"
        set file "$argv[1]"
    end

    curl -F "file=@$file" -H "X-Auth: $(cat ~/.key)" http://localhost:3235/

    if command test -p /dev/stdin
        rm "$file"
    end
end
with jwt tokens
  • you first need to generate them:
curl -u admin http://localhost:3235/token # you can also access the url in the browser directly
  • the user will be the value of $AUTH_USERNAME and password the value of $AUTH_PASSWORD

  • then you use the token in place of the main key:

curl -F"file=@/path/to/file.jpg" -H "X-Auth: your-token" http://localhost:3235/

through the browser

  • you can only upload text through the browser, to do so, simply write text in the form in the default webpage and click upload.
  • this upload can be restricted to need authentication or not, controlled by an environment variable.

theming

  • there is an example homepage in static/ you can edit directly, which the server will serve automatically
  • if running with docker, it's also possible to override /static inside the container with your own page.
    • otherwise you will need to clone this repository and edit static/ and templates/ manually, or recreate the structure.
  • same thing with templates in templates/
    • it is preferred to use dev/ for that reason, since it is git-ignored and that way makes it easier if wanting to update regularly without making changes to the tree

docs

  • ABYSS_URL: this is used for the correct formatting of the response of curl.
  • AUTH_USERNAME | AUTH_PASSWORD: this is used to access /tree, which shows all uploaded files
  • UPLOAD_KEY: this is key checked when uploading files. if the key doesn't match with server's one, then it refuses uploading.
  • ABYSS_FILEDIR: this points to the directory where abyss will save the uploads to. defaults to ./files
  • ABYSS_PORT: this is the port the server will run on. safe to leave empty. defaults to 3235
  • SHOULD_AUTH: if it is yes, then to upload text through the browser you will need authentication (same auth as /tree), any value other than that and upload is auth-less

todo:

  • add upload of logs funcionality (like 0x0.st)
  • add docker easy setup
  • add db for tracking of file names (dont need that)
  • add file browser (like file://)
  • add file extension in its name
  • login prompt when accessing /tree
  • home page
  • custom file displaying!!
  • syntax highlighting
  • add rate limits

pictures

this is abyss' default directory list
this is abyss' default file presentation