Uberfast pastebin in Go
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Stanislav Nikitin d7e58613ba
v 0.1.0
5 years ago
api Passworded pastes are here. 5 years ago
assets Passworded pastes are here. 5 years ago
captcha Captcha and design works. 5 years ago
cmd/fastpastebin Captcha and design works. 5 years ago
config License header everywhere. We're on MIT. 5 years ago
context Pagination, readable error messages to user, syntax highlighting started. 5 years ago
database Passworded pastes are here. 5 years ago
examples gitignore, removed my development config and updated README. 5 years ago
pagination Pagination links fix. 5 years ago
pastes Passworded pastes are here. 5 years ago
systemd Private pastes, systemd unit file, design updates. 5 years ago
vendor Dependencies. 5 years ago
.gitignore gitignore, removed my development config and updated README. 5 years ago
CHANGELOG.md v 0.1.0 5 years ago
Gopkg.lock Dependencies. 5 years ago
Gopkg.toml Initial commit. 5 years ago
LICENSE License header everywhere. We're on MIT. 5 years ago
README.md Gitter lags, all to Keybase! :P 5 years ago
fileb0x.yml Passworded pastes are here. 5 years ago

README.md

Chat on Keybase.io

Fast Pastebin

Easy-to-use-and-install pastebin software written in Go. No bells or whistles, no websockets and even NO JAVASCRIPT!(*)

(*) Except fontawesome, because it's awesome :).

Current functionality.

  • Create and view public and private pastes.
  • Syntax highlighting.
  • Pastes expiration.
  • Passwords for pastes.

Caveats.

Installation and updating

Just issue:

go get -u -v github.com/pztrn/fastpastebin/cmd/fastpastebin

This command can be used to update Fast Paste Bin.

WARNING: installation by compiling Fast Paste Bin from sources require at least 300 megabytes of free RAM! Eventually it'll run even on 64MB-powered VM, it's only a compilation issue.

Configuration.

Take a look at example configuration file which contains all supported options and their descriptions.

Configuration file position is irrelevant, there is no hardcoded paths where Fast Paste Bin looking for it's configuration. Use -config CLI parameter or FASTPASTEBIN_CONFIG environment variable to specify path.

Developing

Developers should install https://github.com/UnnoTed/fileb0x/ which is used as replacement to go-bindata for embedding assets into binary. After changing assets they should be recompiled into Go code. At repository root execute this command and you'll be fine:

fileb0x fileb0x.yml

Also if you're changed list of assets (by creating or deleting them) be sure to fix files list in fileb0x.yml file!

The rest is default - use linters, formatters, etc. VSCode with Go plugin is recommended for developing as it will perform most of linting-formatting actions automagically. Try to follow https://github.com/golang/go/wiki/CodeReviewComments with few exceptions:

ToDo

This is a ToDo list which isn't sorted by any parameter at all. Just a list of tasks you can help with.

  • User CP.
  • Files uploading.
  • Passwords for files.
  • Pastes forking and revisioning (like git or github gists).
  • Possibility to copy-paste-edit WISYWIG content.
  • CLI client for pastes and files uploading.