https://github.com/adyanth/shortpaste
A Go based URL shortener, pastebin and file uploader
https://github.com/adyanth/shortpaste
Last synced: 24 days ago
JSON representation
A Go based URL shortener, pastebin and file uploader
- Host: GitHub
- URL: https://github.com/adyanth/shortpaste
- Owner: adyanth
- License: mit
- Created: 2021-07-15T13:38:27.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-24T05:25:18.000Z (4 months ago)
- Last Synced: 2024-11-24T17:43:12.875Z (3 months ago)
- Language: Vue
- Size: 941 KB
- Stars: 47
- Watchers: 4
- Forks: 8
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Short{Paste}
[data:image/s3,"s3://crabby-images/a1146/a11467435af760e6366e6262ee08d551ffe8e728" alt="Drone Build Status"](https://drone.adyanth.site/adyanth/shortpaste)
[data:image/s3,"s3://crabby-images/5d058/5d058ade0788c6d2775c7f3549ff4ce0e0ccf3cc" alt="Docker pulls"](https://hub.docker.com/r/adyanth/shortpaste)
[data:image/s3,"s3://crabby-images/f1cce/f1cce5f6269701143fde84a89719a6660aff5da9" alt="Docker Compose"](https://git.adyanth.site/DockerComposeApps/shortpaste/src/branch/main/docker-compose.yml)
[data:image/s3,"s3://crabby-images/2490a/2490a2a531b1ed489c2360c9e9b6c9ad867e955b" alt="Go Report"](https://goreportcard.com/report/git.adyanth.site/adyanth/shortpaste)
[data:image/s3,"s3://crabby-images/4e9de/4e9decb000d0f9f4e1cfebdf97b7606d84692749" alt="Demo on Heroku"](https://shortpaste.herokuapp.com/)`Short{Paste}` is open-source software written in Go and VueJS. It is a minimalistic shortener that combines three things that need shortening: links, files, and text. It is a self-hosted alternative to many popular services like paste bin and using dropbox to send a file to someone quickly.
The Go backend handles saving files, links, and text in DB and filesystem as needed, while the Vue UI provides a pretty view for you to add and review content. Added bonus, it tracks hit counts too!
## Deployment
The whole backend packages to a single binary, and I bundled the app as a docker container based on `alpine` favored for its tiny size. To run this yourself, execute the command below.
```bash
docker run -d \
-p 8080:8080 \
-v ${PWD}/shortpaste/:/root/.shortpaste \
adyanth/shortpaste:latest
```The command will publish the application on port `8080`, making it available on `http://localhost:8080/` and use the bind-mounted folder called `shortpaste` in your current working directory to save the SQLite DB, the files, and texts published.
If you prefer docker-compose, here is an [example deployment](https://git.adyanth.site/DockerComposeApps/shortpaste).
## Build it yourself
With docker, you can build this yourself. A `Dockerfile` is provided at the root of this repository.
It uses a multi-stage build consisting of three stages:
- Go Build : Builds a statically linked Go binary containing the backend API server and the static server.
- Vue Build : Builds the VueJS UI to generate a `dist` folder with resources.
- Container : Alpine container where the binary and `dist` are copied and served.## Environment Variables
You can customize the behavior using environment variables. Here is a list of configurable parameters.
| Environment Variable | Default Value | Behaviour |
| -------------------- | ----------------- | ------------------------------------------------------------------------------------------------------------------ |
| `SP_BIND_ADDR` | `":8080"` | Sets the bind-address inside the container. |
| `PORT` | | If set, it overrides the `SP_BIND_ADDR` to use the given port on all interfaces (support for Heroku deployment) |
| `SP_STORAGE_PATH` | `"~/.shortpaste"` | Sets the location for saving data inside the container. |
| `SP_307_REDIRECT` | | Setting this to anything causes a 307 redirect to be sent instead of showing the landing page for shortened links. |
| `SP_USERNAME` | `admin` | Sets the username to login to the UI (only applies to creating resources, links will still work fine) |
| `SP_PASSWORD` | `admin` | Sets the password to login to the UI (only applies to creating resources, links will still work fine) |
| `SP_NOAUTH` | | Setting this to anything bypasses authentication for creating resources. |## Screenshots
Here are some screenshots to get a taste of it, see the [demo](https://shortpaste.herokuapp.com/) for more :)
| Type | Create | View |
| :---: | :-----------------------------: | :--------------------------------: |
| Links | data:image/s3,"s3://crabby-images/d55bd/d55bd1a9d8fc5e0310368666c5b98600a107db87" alt="Link Upload" | data:image/s3,"s3://crabby-images/0dac9/0dac994a6bdceb47e8e7a3c772118ff6c22a3c70" alt="Link View" |
| Text | data:image/s3,"s3://crabby-images/cd846/cd846a5834fa399f17ba50b60d447bb2b7470bc7" alt="Text Upload" | data:image/s3,"s3://crabby-images/fabab/fabab51ba24a9c65431a5e8684ee42ceb85f21aa" alt="Text View" |
| Files | data:image/s3,"s3://crabby-images/6a90e/6a90e6144e781c41d996be96652b9499abbbb786" alt="File Upload" | data:image/s3,"s3://crabby-images/5665b/5665b0d185d26bc7a8a51559530d287cd2a73e75" alt="File View" |