Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sharzyl/pastebin-worker
Pastebin on Cloudflare worker, with friendly CLI usage and rich features
https://github.com/sharzyl/pastebin-worker
cloudflare-worker pastebin self-hosted wrangler
Last synced: 3 days ago
JSON representation
Pastebin on Cloudflare worker, with friendly CLI usage and rich features
- Host: GitHub
- URL: https://github.com/sharzyl/pastebin-worker
- Owner: SharzyL
- License: mit
- Created: 2021-03-28T16:40:15.000Z (almost 4 years ago)
- Default Branch: goshujin
- Last Pushed: 2024-12-22T03:38:02.000Z (18 days ago)
- Last Synced: 2024-12-30T03:02:28.450Z (10 days ago)
- Topics: cloudflare-worker, pastebin, self-hosted, wrangler
- Language: JavaScript
- Homepage: https://shz.al
- Size: 418 KB
- Stars: 760
- Watchers: 7
- Forks: 242
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pastebin-worker
This is a pastebin that can be deployed on Cloudflare workers. Try it on [shz.al](https://shz.al).
**Philosophy**: effortless deployment, friendly CLI usage, rich functionality.
**Features**:
1. Share your paste with as short as 4 characters
2. Customize the paste URL
4. **Update** and **delete** your paste as you want
5. **Expire** your paste after a period of time
6. **Syntax highlighting** powered by PrismJS
7. Display **markdown** file as HTML
8. Used as a URL shortener
9. Customize returned mimetype## Usage
1. You can post, update, delete your paste directly on the website (such as [shz.al](https://shz.al)).
2. It also provides a convenient HTTP API to use. See [API reference](doc/api.md) for details. You can easily call API via command line (using `curl` or similar tools).
3. [pb](/scripts) is a bash script to make it easier to use on command line.
## Limitations
1. If deployed on Cloudflare Worker free-tier plan, the service allows at most 100,000 reads and 1000 writes, 1000 deletes per day.
2. Due to the size limit of Cloudflare KV storage, the size of each paste is bounded under 25 MB.## Deploy
You are free to deploy the pastebin on your own domain if you host your domain on Cloudflare.
1. Install `node` and `yarn`.
2. Create a KV namespace on Cloudflare workers dashboard, remember its ID.
3. Clone the repository and enter the directory.
4. Modify entries in `wrangler.toml`. Its comments will tell you how.
5. Login to Cloudflare and deploy with the following steps:
```console
$ yarn install
$ yarn wrangler login
$ yarn deploy
```6. Enjoy!
## Auth
If you want a private deployment (only you can upload paste, but everyone can read the paste), add the following entry to your `wrangler.toml`.
```toml
[vars.BASIC_AUTH]
user1 = "passwd1"
user2 = "passwd2"
```Now every access to POST request, and every access to static pages, requires an HTTP basic auth with the user-password pair listed above. For example:
```console
$ curl example-pb.com
HTTP basic auth is required$ curl -Fc=@/path/to/file example-pb.com
HTTP basic auth is required$ curl -u admin1:wrong-passwd -Fc=@/path/to/file example-pb.com
Error 401: incorrect passwd for basic auth$ curl -u admin1:this-is-passwd-1 -Fc=@/path/to/file example-pb.com
{
"url": "https://example-pb.com/YCDX",
"suggestUrl": null,
"admin": "https://example-pb.com/YCDX:Sij23HwbMjeZwKznY3K5trG8",
"isPrivate": false
}
```## Administration
Delete a paste:
```console
$ yarn delete-paste
```List pastes:
```console
$ yarn -s wrangler kv:key list --binding PB > kv_list.json
```## Development
Run a local simulator:
```console
$ yarn dev
```Run tests:
```console
$ yarn test
```Run tests with coverage report:
```console
$ yarn coverage
```