Pastebin on Cloudflare worker, with friendly CLI usage and rich features
This is a pastebin that can be deployed on Cloudflare workers. Try it on shz.al.
Philosophy: effortless deployment, friendly CLI usage, rich functionality.
Features:
You can post, update, delete your paste directly on the website (such as shz.al).
It also provides a convenient HTTP API to use. See API reference for details. You can easily call API via command line (using curl
or similar tools).
pb is a bash script to make it easier to use on command line.
You are free to deploy the pastebin on your own domain if you host your domain on Cloudflare.
Install node
and yarn
.
Create a KV namespace on Cloudflare workers dashboard, remember its ID.
Clone the repository and enter the directory. Login to your Cloudflare account with wrangler login
.
Modify entries in wrangler.toml
. Its comments will tell you how.
Deploy and enjoy!
$ yarn install
$ yarn deploy
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
.
[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:
$ 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
}
Delete a paste:
$ yarn delete-paste <name-of-paste>
List pastes:
$ yarn wrangler kv:key list --binding PB > kv_list.json
Run a local simulator:
$ yarn dev
Run tests:
$ yarn test
Run tests with coverage report:
$ yarn coverage