Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Pastebin on Cloudflare worker, with friendly CLI usage and rich features

License

NotificationsYou must be signed in to change notification settings

Nyvryl/pastebin-worker

 
 

Repository files navigation

This is a pastebin that can be deployed on Cloudflare workers. Try it onshz.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
  3. Update anddelete your paste as you want
  4. Expire your paste after a period of time
  5. Syntax highlighting powered by PrismJS
  6. Displaymarkdown file as HTML
  7. Used as a URL shortener
  8. Customize returned mimetype

Usage

  1. You can post, update, delete your paste directly on the website (such asshz.al).

  2. It also provides a convenient HTTP API to use. SeeAPI reference for details. You can easily call API via command line (usingcurl or similar tools).

  3. pb 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. Installnode andyarn.

  2. Create a KV namespace on Cloudflare workers dashboard, remember its ID.

  3. Clone the repository and enter the directory.

  4. Modify entries inwrangler.toml. Its comments will tell you how.

  5. Login to Cloudflare and deploy with the following steps:

$yarn install$yarn wrangler login$yarn deploy
  1. Enjoy!

Auth

If you want a private deployment (only you can upload paste, but everyone can read the paste), add the following entry to yourwrangler.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.comHTTP basic auth is required$curl -Fc=@/path/to/file example-pb.comHTTP basic auth is required$curl -u admin1:wrong-passwd -Fc=@/path/to/file example-pb.comError 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:

$yarn delete-paste<name-of-paste>

List pastes:

$yarn wrangler kv:key list --binding PB> kv_list.json

Development

Run a local simulator:

$yarn dev

Run tests:

$yarntest

Run tests with coverage report:

$yarn coverage

About

Pastebin on Cloudflare worker, with friendly CLI usage and rich features

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript73.2%
  • Shell18.8%
  • HTML8.0%

[8]ページ先頭

©2009-2025 Movatter.jp