2018-04-30 18:42:17 +05:00
# Fast Pastebin
2020-02-29 23:51:23 +05:00
[![Drone (self-hosted) ](https://img.shields.io/drone/build/fastpastebin/fastpastebin?server=https%3A%2F%2Fci.dev.pztrn.name )](https://ci.dev.pztrn.name/fastpastebin/fastpastebin/) [![Discord ](https://img.shields.io/discord/632359730089689128 )](https://discord.gg/qHN6KsD) ![Keybase XLM ](https://img.shields.io/keybase/xlm/pztrn )
Easy-to-use-and-install pastebin software written in Go. No bells or whistles, no websockets and even NO JAVASCRIPT!
2018-05-01 14:41:36 +05:00
2020-02-29 23:51:23 +05:00
## Current functionality
2018-05-01 14:41:36 +05:00
2018-05-02 11:29:29 +05:00
* Create and view public and private pastes.
2018-05-01 14:41:36 +05:00
* Syntax highlighting.
2018-05-17 22:43:15 +05:00
* Pastes expiration.
2018-05-18 22:50:32 +05:00
* Passwords for pastes.
2019-10-13 14:50:11 +05:00
* Multiple storage backends. Currently: ``flatfiles``, ``mysql`` and ``postgresql``.
2018-05-01 14:41:36 +05:00
2020-02-29 23:51:23 +05:00
## Caveats
2018-05-01 14:41:36 +05:00
2020-02-29 23:51:23 +05:00
* No links at lines numbers. See [this Chroma bug ](https://github.com/alecthomas/chroma/issues/132 )
2018-04-30 22:43:14 +05:00
2020-02-29 23:51:23 +05:00
## Installation and updating
2018-04-30 22:43:14 +05:00
Just issue:
2020-02-29 23:51:23 +05:00
```bash
2019-10-13 14:50:11 +05:00
CGO_ENABLED=0 go get -u -v go.dev.pztrn.name/fastpastebin/cmd/fastpastebin
2018-04-30 22:43:14 +05:00
```
This command can be used to update Fast Paste Bin.
2020-02-29 23:51:23 +05:00
## Configuration
2018-04-30 22:43:14 +05:00
2020-02-29 23:51:23 +05:00
Take a look at [example configuration file ](examples/fastpastebin.yaml.dist ) which contains all supported options and their descriptions.
2018-04-30 22:43:14 +05:00
2020-02-29 23:51:23 +05:00
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.
2018-04-30 22:48:05 +05:00
2020-02-29 23:51:23 +05:00
## Developing
2018-05-01 15:01:40 +05:00
2020-02-29 23:51:23 +05:00
Developers should install [fileb0x ](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:
2018-05-01 15:01:40 +05:00
2020-02-29 23:51:23 +05:00
```bash
2018-05-01 15:01:40 +05:00
fileb0x fileb0x.yml
```
2020-02-29 23:51:23 +05:00
Also if you're changed list of assets (by creating or deleting them) be sure to fix files list in ``fileb0x.yml`` file!
2018-05-01 15:01:40 +05:00
2020-02-29 23:51:23 +05:00
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 [Go's code review comments ](https://github.com/golang/go/wiki/CodeReviewComments ) with few exceptions:
2018-05-01 15:01:40 +05:00
2020-02-29 23:51:23 +05:00
* Imports should be organized in 3 groups: stdlib, local, other. See [this file ](https://sources.dev.pztrn.name/fastpastebin/fastpastebin/src/branch/master/domains/pastes/paste_get.go ) for example.
* We're not forcing any limits on line length for code, only for comments, they should be 72-76 chars long.
2018-05-01 15:01:40 +05:00
2020-02-29 23:51:23 +05:00
## ToDo
2018-04-30 22:48:05 +05:00
2020-02-29 23:51:23 +05:00
This is a ToDo list which isn't sorted by any parameter at all. Just a list of tasks you can help with.
2018-04-30 22:48:05 +05:00
* User CP.
* Files uploading.
2018-05-18 22:50:32 +05:00
* Passwords for files.
2018-04-30 22:48:05 +05:00
* Pastes forking and revisioning (like git or github gists).
2020-02-29 23:51:23 +05:00
* Possibility to copy-paste-edit WYSIWYG content.
* CLI client for pastes and files uploading.